आपको Apigee Edge दस्तावेज़ दिख रहा है.
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
इस पेज पर जाएं
Apigee X दस्तावेज़. जानकारी
समस्या का ब्यौरा
क्लाइंट ऐप्लिकेशन को गड़बड़ी कोड के साथ 400 Bad Request का एक एचटीटीपी स्टेटस कोड मिलता है
protocol.http.DuplicateHeader का इस्तेमाल, एपीआई कॉल के रिस्पॉन्स के तौर पर किया जाता है.
गड़बड़ी का मैसेज
क्लाइंट ऐप्लिकेशन को यह रिस्पॉन्स कोड मिलता है:
HTTP/1.1 400 Bad Request
इसके अलावा, आपको गड़बड़ी का ऐसा मैसेज भी दिख सकता है जो नीचे दिए गए मैसेज से मिलता-जुलता है:
{
"fault":{
"faultstring":"Duplicate Header \"Expires\"",
"detail":{
"errorcode":"protocol.http.DuplicateHeader"
}
}
}संभावित कारण
यह गड़बड़ी तब होती है, जब कोई ऐसा एचटीटीपी हेडर हो जिसे Apigee में डुप्लीकेट बनाने की अनुमति नहीं है Edge, इनके भेजे गए एचटीटीपी अनुरोध के हिस्से के तौर पर एक ही या अलग-अलग वैल्यू के साथ एक से ज़्यादा बार दिखता है क्लाइंट को Apigee Edge पर भेजना है.
के अनुसार
आरएफ़सी 7230, सेक्शन 3.2.2: फ़ील्ड ऑर्डर, ईमेल भेजने वाले को एक से ज़्यादा हेडर जनरेट नहीं करना चाहिए
किसी मैसेज में उसी फ़ील्ड नाम के साथ फ़ील्ड शामिल करें, जब तक कि उसके लिए पूरा फ़ील्ड मान न हो
हेडर फ़ील्ड को कॉमा लगाकर अलग की गई सूची के तौर पर दिखाया जाता है, [यानी, #(values)] या हेडर फ़ील्ड
लोकप्रिय अपवाद. अगर Apigee Edge को कोई खास हेडर मिलता है, तो
डुप्लीकेट हैं, तो क्लाइंट के एचटीटीपी अनुरोध में एक से ज़्यादा बार शामिल है, तो
400 Bad Request और गड़बड़ी कोड के साथ जवाब देता है
protocol.http.DuplicateHeader.
इस गड़बड़ी की ये वजहें हो सकती हैं:
| वजह | ब्यौरा | इसके लिए लागू होने वाले, समस्या हल करने के निर्देश |
|---|---|---|
| डुप्लीकेट हेडर का अनुरोध किया गया है | क्लाइंट ऐप्लिकेशन से Apigee को भेजे गए एचटीटीपी अनुरोध में डुप्लीकेट हेडर शामिल हैं. | Edge के सार्वजनिक और प्राइवेट क्लाउड उपयोगकर्ता |
गड़बड़ी की जांच करने के सामान्य तरीके
इस गड़बड़ी का पता लगाने के लिए, इनमें से किसी एक टूल/तकनीक का इस्तेमाल करें:
एपीआई मॉनिटरिंग
एपीआई मॉनिटरिंग का इस्तेमाल करके, गड़बड़ी का पता लगाने के लिए:
- Apigee Edge के यूज़र इंटरफ़ेस (यूआई) में ऐसे उपयोगकर्ता के तौर पर साइन इन करें जिसके साथ की भूमिका होनी चाहिए.
उस संगठन पर जाएं जिसमें आपको समस्या की जांच करनी है.

- विश्लेषण करें > एपीआई मॉनिटरिंग > पेज की जांच करें.
- वह समयावधि चुनें जिसमें आपको गड़बड़ियां दिखी थीं.
- पक्का करें कि प्रॉक्सी फ़िल्टर सभी पर सेट है.
- समय के हिसाब से गड़बड़ी कोड दिखाएं.
वह सेल चुनें जिसमें गड़बड़ी का कोड
protocol.http.DuplicateHeaderहै जैसा कि नीचे दिखाया गया है:
गड़बड़ी कोड
protocol.http.DuplicateHeaderके बारे में जानकारी यह है नीचे दिखाए गए तरीके से दिखाया गया है:
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
- लॉग देखें पर क्लिक करें और फ़ेल हो चुके अनुरोध की पंक्ति को बड़ा करें.
- लॉग विंडो में जाकर, यह जानकारी देखें:
- स्टेटस कोड:
400 - गलत सोर्स:
apigee - गलत कोड:
protocol.http.DuplicateHeader.
- स्टेटस कोड:
- अगर गलत सोर्स की वैल्यू
apigeeयाMPहै और गलत कोड की वैल्यूprotocol.http.DuplicateHeaderहै, तो इससे पता चलता है कि एचटीटीपी अनुरोध क्लाइंट में डुप्लीकेट हेडर हैं.
ट्रेस करने वाला टूल
NGINX
NGINX ऐक्सेस लॉग का इस्तेमाल करके गड़बड़ी का पता लगाने के लिए:
- अगर आप निजी Cloud उपयोगकर्ता हैं, तो यह पता करने के लिए कि NGINX ऐक्सेस लॉग का इस्तेमाल किया जा सकता है या नहीं
एचटीटीपी
400गड़बड़ियों के बारे में अहम जानकारी. NGINX ऐक्सेस लॉग देखें:
/opt/apigee/var/log/edge-router/nginx/ORG~ENV.PORT#_access_logकहां: ORG, ENV और PORT# को इससे बदल दिया गया है सेट करें.
- यह देखने के लिए खोजें कि किसी विशेष अवधि के दौरान कोई
400गड़बड़ी हुई है या नहीं (अगर समस्या पिछली बार हुई है) या अगर कोई अनुरोध अब भी पूरा नहीं हो पा रहा है400. अगर आपको X-Apigee-fault-code के साथ कोई
400गड़बड़ी मिलती हैprotocol.http.DuplicateHeaderके मान से मेल खा रहा है, फिर X-Apigee-fault-source. की वैल्यू तय करें.NGINX ऐक्सेस लॉग में 400 कोड वाली गड़बड़ी का सैंपल:
NGINX ऐक्सेस लॉग की ऊपर दी गई सैंपल एंट्री में X-Apigee- के लिए ये वैल्यू हैं गड़बड़ी का कोड और X-Apigee-fault-source:
रिस्पॉन्स हेडर मान X-Apigee-fault-code protocol.http.DuplicateHeaderX-Apigee-fault-source MP
वजह: अनुरोध में डुप्लीकेट हेडर मिला है
संक्रमण की जांच
- एपीआई का इस्तेमाल करके मिली गड़बड़ी के लिए, गलत कोड और गलत सोर्स का पता लगाएं मॉनिटरिंग या NGINX ऐक्सेस लॉग के बारे में जानकारी, जैसा कि गड़बड़ी की जानकारी देने के सामान्य तरीके में बताया गया है.
- अगर गलत सोर्स की वैल्यू
apigeeयाMPहै, तो इससे पता चलता है कि क्लाइंट ऐप्लिकेशन से Apigee को भेजे गए अनुरोध में डुप्लीकेट मौजूद है हेडर. इसका इस्तेमाल करके, अनुरोध के हिस्से के तौर पर एक से ज़्यादा बार भेजे जाने वाले असल हेडर का पता लगाया जा सकता है नीचे दिए गए तरीकों में से कोई एक तरीका अपनाएं:
गड़बड़ी का मैसेज
गड़बड़ी के मैसेज का इस्तेमाल करना
अगर आपके पास Apigee Edge से मिले, गड़बड़ी के पूरे मैसेज का ऐक्सेस है, तो
faultstringदेखें.faultstringमें हेडर नाम जो एक से ज़्यादा बार भेजा गया है.गड़बड़ी के मैसेज का उदाहरण:
"faultstring":"Duplicate Header \"Expires\""
- ऊपर दिए गए गड़बड़ी के मैसेज में, आप देख सकते हैं कि हेडर
Expiresको एक से ज़्यादा बार भेजा गया है, जैसा किfaultstringमें देखा गया है.
असल अनुरोध
असल अनुरोध का इस्तेमाल करना
अगर आपके पास क्लाइंट ऐप्लिकेशन के असल अनुरोध का ऐक्सेस है, तो यह तरीका अपनाएं:
- अनुरोध में पास किए गए हेडर की सूची की पुष्टि करें.
- अगर आपको लगता है कि कोई हेडर, अनुरोध नहीं किया है या अलग-अलग वैल्यू डाली हैं , तो यह वजह है इस गड़बड़ी को ठीक करने के लिए.
अनुरोध का सैंपल:
curl https://HOST_ALIAS/duplicateheadertest -v -H "Expires: Mon, 21 June 2021 07:28:00 GMT" -H "Expires: Mon, 21 June 2021 07:28:00 GMT"
ऊपर दिए गए उदाहरण अनुरोध में, हेडर
Expiresको इससे ज़्यादा एक बार. इसलिए, यह अनुरोध400 Bad Requestगड़बड़ी की वजह से पूरा नहीं हो पाता है और गड़बड़ी कोड:protocol.http.DuplicateHeader.- इसके अलावा, अगर आपके पास क्लाइंट लॉग का ऐक्सेस है, तो देखें कि Apigee Edge को किए गए असल अनुरोध के बारे में जानकारी देता है और हेडर तय करता है कि एक से ज़्यादा बार भेजा गया हो.
रिज़ॉल्यूशन
डुप्लीकेशन ठीक करें
पहला विकल्प [सुझाया गया विकल्प] क्लाइंट ऐप्लिकेशन को ठीक करें, ताकि डुप्लीकेट हेडर शामिल न किए जा सकें
- किसी क्लाइंट के डुप्लीकेट हेडर भेजने की वजह का विश्लेषण करें. उदाहरण के लिए,
ऊपर दिए गए मामले में
Expires. पुष्टि करें कि एपीआई प्रॉक्सी के लिए इसे स्वीकार करना सही है हेडर को कॉपी करना. आम तौर पर, एचटीटीपी स्पेसिफ़िकेशन के मुताबिक ऐसा करने की अनुमति नहीं है RFC7230. - अगर यह ज़रूरी नहीं है, तो अपने क्लाइंट ऐप्लिकेशन में बदलाव करें, ताकि डुप्लीकेट हेडर न भेजे जाएं.
ऊपर बताए गए उदाहरण में, यह पता चला है कि हेडर
Expiresभेजा गया है समान मान के साथ दो बार ऐसा करें, जो अवांछनीय नहीं है. समस्या को हल करने के लिए,Expiresहेडर सिर्फ़ एक बार नीचे दिखाया गया है:curl https://HOST_ALIAS/duplicateheadertest -v -H "Expires: Mon, 21 June 2021 07:28:00 GMT"
- अगर आपको डुप्लीकेट हेडर की अनुमति देनी है, तो यहां जाएं CwC प्रॉपर्टी का इस्तेमाल करने का दूसरा विकल्प.
CwC
दूसरा विकल्प CwC प्रॉपर्टी का इस्तेमाल करना
Apigee, डेवलपर को
CwC प्रॉपर्टी HTTPHeader.<HeaderName> ,जिससे क्लाइंट
का इस्तेमाल करें.
| CwC प्रॉपर्टी | वैल्यू |
|---|---|
HTTPHeader.<HeaderName> |
allowDuplicates,multivalued |
उदाहरण के लिए, डुप्लीकेट मैसेज और ईमेल को अनुमति देने के लिए, मैसेज प्रोसेसर पर इस प्रॉपर्टी को सेट किया जा सकता है
हेडर Expires के लिए एक से ज़्यादा वैल्यू.
HTTPHeader.Expires=allowDuplicates, multiValued
- अगर आप निजी Cloud उपयोगकर्ता हैं, तो आपके पास प्रॉपर्टी को कॉन्फ़िगर करने का विकल्प होता है, ताकि
Apigee Edge,
400 Bad Requestगड़बड़ी पैदा करने की अनुमति नहीं देता, भले ही अनुरोध किया गया हो इसमें का इस्तेमाल करने वाले डुप्लीकेट हेडर हैं डुप्लीकेट हेडर इस्तेमाल करने के लिए, मैसेज प्रोसेसर को कॉन्फ़िगर करने का तरीका. - अगर आप सार्वजनिक क्लाउड के उपयोगकर्ता हैं, तो इस प्रॉपर्टी को कॉन्फ़िगर करने के लिए, Apigee Edge की सहायता टीम से संपर्क करें एक ही उपयोगकर्ता नाम देना ज़रूरी है.
खास जानकारी
Apigee को उम्मीद है कि क्लाइंट ऐप्लिकेशन, अनुरोध के हिस्से के तौर पर डुप्लीकेट हेडर नहीं भेजे आरएफ़सी के नीचे दिए गए निर्देशों के मुताबिक:
| खास जानकारी |
|---|
| आरएफ़सी 7230, सेक्शन 3.2.2: फ़ील्ड ऑर्डर |
| आरएफ़सी 7230, सेक्शन 3.2 हेडर फ़ील्ड |
अगर आपको अब भी Apigee की सहायता टीम से कोई मदद चाहिए, तो यहां जाएं गड़बड़ी की जानकारी इकट्ठा करना ज़रूरी है.
ऐप्लिकेशन की परफ़ॉर्मेंस से जुड़ी जानकारी इकट्ठा करना ज़रूरी है
गड़बड़ी की जानकारी इकट्ठा करें. इसके बाद, Apigee Edge की सहायता टीम से संपर्क करें.
अगर आप सार्वजनिक क्लाउड के उपयोगकर्ता हैं, तो यह जानकारी दें:
- संगठन का नाम
- परिवेश का नाम
- एपीआई प्रॉक्सी का नाम
400गड़बड़ी को ठीक करने के लिए इस्तेमाल किए गएcurlनिर्देश को पूरा करें- एपीआई अनुरोधों के लिए फ़ाइल ट्रेस करें
अगर आप निजी Cloud उपयोगकर्ता हैं, तो यह जानकारी दें:
- पूरे न हो पाने वाले अनुरोधों की वजह से, गड़बड़ी का पूरा मैसेज मिला
- परिवेश का नाम
- एपीआई प्रॉक्सी बंडल
curlनिर्देश पूरा करें, जिसका इस्तेमाल आपने400गड़बड़ी को ठीक करने के लिए किया था- एपीआई अनुरोधों के लिए फ़ाइल ट्रेस करें
NGINX ऐक्सेस के लॉग:
/opt/apigee/var/log/edge-router/nginx/ORG~ENV.PORT#_access_logकहां: ORG, ENV और PORT# को इससे बदल दिया गया है सेट करें.
- मैसेज प्रोसेसर के सिस्टम लॉग
/opt/apigee/var/log/edge-message-processor/logs/system.logअभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है