निकालें वैरिएबल नीति

आपको Apigee Edge दस्तावेज़ दिख रहा है.
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है इस पेज पर जाएं Apigee X दस्तावेज़.
जानकारी

क्या

ExtractVariables नीति किसी अनुरोध या जवाब से कॉन्टेंट निकालती है और एक वैरिएबल जोड़ा जा सकता है. आपके पास मैसेज का कोई भी हिस्सा एक्सट्रैक्ट करने का विकल्प होता है. इसमें हेडर, यूआरआई पाथ, JSON/एक्सएमएल पेलोड, फ़ॉर्म शामिल हैं पैरामीटर, और क्वेरी पैरामीटर. यह नीति, मैसेज पर टेक्स्ट पैटर्न लागू करके काम करती है कॉन्टेंट और मिलता-जुलता कॉन्टेंट मिलने पर, तय किए गए मैसेज कॉन्टेंट के साथ वैरिएबल सेट करता है.

वैसे तो आप किसी अनुरोध या जवाब वाले मैसेज से जानकारी निकालने के लिए अक्सर इस नीति का इस्तेमाल करते हैं, लेकिन आप का इस्तेमाल दूसरे सोर्स से जानकारी निकालने के लिए भी किया जा सकता है. इनमें, AccessEntity की नीति, एक्सएमएल ऑब्जेक्ट या JSON ऑब्जेक्ट.

तय किए गए मैसेज का कॉन्टेंट एक्सट्रैक्ट करने के बाद, इस वैरिएबल का रेफ़रंस दूसरे नीति का पालन करना ज़रूरी है.

वीडियो

ExtractVariables की नीति के बारे में ज़्यादा जानने के लिए ये वीडियो देखें.

वीडियो ब्यौरा
वैरिएबल एक्सट्रैक्ट करना को एक्सएमएल पेलोड से वैरिएबल एक्सट्रैक्ट करने की नीति का इस्तेमाल करके, एक्सएमएल पेलोड से वैरिएबल निकालें.
वैरिएबल एक्सट्रैक्ट करना JSON पेलोड से वैरिएबल एक्सट्रैक्ट करने की नीति का इस्तेमाल करके, JSON पेलोड से वैरिएबल एक्सट्रैक्ट करें.
वैरिएबल एक्सट्रैक्ट करना पैरामीटर से क्वेरी, हेडर, फ़ॉर्म या यूआरआई पैरामीटर जैसे पैरामीटर से वैरिएबल निकालें.
वैरिएबल एक्सट्रैक्ट करना कई वैल्यू वाले पैरामीटर से एक से ज़्यादा वैल्यू वाले पैरामीटर से वैरिएबल निकालें.
वैरिएबल एक्सट्रैक्ट करना क्वेरी पैरामीटर (क्लासिक Edge) से क्लासिक एज यूआई का इस्तेमाल करके, क्वेरी पैरामीटर से वैरिएबल निकालें.
वैरिएबल एक्सट्रैक्ट करना को एक्सएमएल या JSON पेलोड (क्लासिक एज) से क्लासिक Edge यूज़र इंटरफ़ेस (यूआई) का इस्तेमाल करके एक्सएमएल या JSON पेलोड से वैरिएबल निकालें.

सैंपल

नीति कोड के ये सैंपल दिखाते हैं कि नीचे दिए गए टाइप के वैरिएबल से वैरिएबल कैसे निकालें आर्टफ़ैक्ट:

GitHub

ये लिंक, काम करने वाले ऐसे एपीआई प्रॉक्सी सैंपल पर ले जाते हैं जिन्हें आप Edge पर डिप्लॉय कर सकते हैं और चला सकते हैं. वे ExtractVariables का इस्तेमाल करते हैं और वे Apigee के api-platform-सैंपल रिपॉज़िटरी में मौजूद हैं, जहां GitHub. READMEs बताते हैं कि हर केस में ExtractVariables का इस्तेमाल कैसे किया जाता है. साथ ही, प्रत्येक नमूने को चलाएं.

यूआरआई

<ExtractVariables name="ExtractVariables-1">
   <DisplayName>Extract a portion of the url path</DisplayName>
   <Source>request</Source>
   <URIPath>
      <Pattern ignoreCase="true">/accounts/{id}</Pattern>
   </URIPath>
   <VariablePrefix>urirequest</VariablePrefix>
   <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
</ExtractVariables>

ऊपर दिए गए नीति कोड का उदाहरण देखें. <URIPath> एलिमेंट से यह पता चलता है यूआरआई पाथ से जानकारी निकालने के लिए ExtractVariables नीति का इस्तेमाल करें. कॉन्टेंट बनाने <Pattern> एलिमेंट, यूआरआई पाथ पर लागू होने वाला पैटर्न बताता है. कॉन्टेंट बनाने पैटर्न को एक सामान्य टेंप्लेट के तौर पर माना जाता है. इसमें कर्ली ब्रैकेट अलग-अलग हिस्से को दिखाते हैं का यूआरआई पाथ का इस्तेमाल किया जा रहा है.

सेट किए जाने वाले वैरिएबल का नाम, <VariablePrefix> एलिमेंट और कर्ली ब्रैकेट {} में मौजूद वैल्यू <Pattern> एलिमेंट में. दोनों वैल्यू को इंटरवेंशन डॉट से जोड़ा जाता है, जिससे उदाहरण के लिए, urirequest.id का वैरिएबल नाम मिलेगा. अगर कोई <VariablePrefix> एलिमेंट का इस्तेमाल करता है, तो वैरिएबल का नाम सिर्फ़ वैल्यू होता है कर्ली ब्रेसेस में.

ऊपर दिए गए नीति कोड के नमूने को, आने वाले इन अनुरोधों के साथ काम करें:

GET http://org1-test.apigee.net/svc1/accounts/12797282

मान लीजिए कि एपीआई प्रॉक्सी का बेसपाथ /svc1 है. जब Apigee Edge इन शर्तों को लागू करता है इस इनकमिंग अनुरोध के ऊपर ExtractVariables नीति कोड को सेट करता है, यह वैरिएबल को सेट करता है 12797282 के लिए urirequest.id. Apigee Edge की मदद से नीति लागू करने के बाद, प्रोसेसिंग फ़्लो की बाद की नीतियां या कोड, स्ट्रिंग की वैल्यू 12797282 पाने के लिए, urirequest.id.

उदाहरण के लिए, नीचे दी गई AssignmentsMessage नीति, उस वैरिएबल की वैल्यू को अनुरोध के नए मैसेज का पेलोड:

<AssignMessage async="false" continueOnError="false" enabled="true" name="AssignPayload">
 <DisplayName>AssignPayload</DisplayName>
  <Set>
   <Payload contentType="text/xml">
    <IdExtractedFromURI>{urirequest.id}</IdExtractedFromURI>
   </Payload>
  </Set>
  <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
  <AssignTo createNew="true" transport="http" type="request">newRequest</AssignTo>
</AssignMessage>

क्वेरी पैरामीटर

<ExtractVariables name="ExtractVariables-2">
   <DisplayName>Extract a value from a query parameter</DisplayName>
   <Source>request</Source>
   <QueryParam name="code">
      <Pattern ignoreCase="true">DBN{dbncode}</Pattern>
   </QueryParam>
   <VariablePrefix>queryinfo</VariablePrefix>
   <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
</ExtractVariables>

ऊपर दिए गए नीति कोड के नमूने को, आने वाले इन अनुरोधों के साथ काम करें:

GET http://org1-test.apigee.net/accounts/12797282?code=DBN88271

जब Apigee Edge, आने वाले इस अनुरोध के लिए ऊपर मौजूद ExtractVariables नीति कोड को लागू करता है, तो यह वैरिएबल queryinfo.dbncode को 88271 पर सेट करता है. Apigee Edge के बाद नीति को लागू करता है, तो प्रोसेसिंग फ़्लो में आने वाली बाद की नीतियां या कोड ये देख सकते हैं: स्ट्रिंग की वैल्यू 88271 पाने के लिए, queryinfo.dbncode नाम वाला वैरिएबल.

अब आपके पास अपनी प्रॉक्सी में वैरिएबल queryinfo.dbncode को ऐक्सेस करने का विकल्प है. उदाहरण के लिए, नीचे दी गई AssignmentsMessage नीति, इसे अनुरोध के पेलोड में कॉपी करती है:

<AssignMessage async="false" continueOnError="false" enabled="true" name="GetURIPath">
 <DisplayName>GetQP</DisplayName>
  <Set>
   <Payload contentType="text/xml">
    <ExtractQP>{queryinfo.dbncode}</ExtractQP>
   </Payload>
  </Set>
  <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
  <AssignTo createNew="false" transport="http" type="request"/>
</AssignMessage>

एक से ज़्यादा पैरामीटर

<ExtractVariables name="ExtractVariables-2">
   <DisplayName>Extract a value from a query parameter</DisplayName>
   <Source>request</Source>
   <QueryParam name="w">
      <Pattern ignoreCase="true">{firstWeather}</Pattern>
   </QueryParam>
   <QueryParam name="w.2">
     <Pattern ignoreCase="true">{secondWeather}</Pattern>
   </QueryParam>
   <VariablePrefix>queryinfo</VariablePrefix>
 <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
</ExtractVariables>

मान लें कि आपके एपीआई डिज़ाइन की मदद से, एक से ज़्यादा क्वेरी पैरामीटर तय किए जा सकते हैं नाम. इस नीति का इस्तेमाल करके, किसी क्वेरी के एक से ज़्यादा इंस्टेंस की वैल्यू एक्सट्रैक्ट की जा सकती है पैरामीटर "w". ExtractVariables नीति में इन क्वेरी पैरामीटर का रेफ़रंस देने के लिए, आपको इंडेक्स का इस्तेमाल करता है, जहां क्वेरी पैरामीटर के पहले इंस्टेंस में कोई इंडेक्स नहीं है और दूसरा इंडेक्स 2, इंडेक्स 3 में तीसरा वगैरह.

ऊपर दिए गए नीति कोड के नमूने को, आने वाले इन अनुरोधों के साथ काम करें:

GET http://org1-test.apigee.net/weather?w=Boston&w=Chicago

जब Apigee Edge, आने वाले इस अनुरोध के लिए ऊपर मौजूद ExtractVariables नीति कोड को लागू करता है, तो यह वैरिएबल queryinfo.firstWeather को Boston पर सेट करता है और वैरिएबल queryInfo.secondWeather से Chicago तक.

अब आपके पास queryinfo.firstWeather वैरिएबल का ऐक्सेस है और इसमें queryinfo.secondWeather इसमें आपका प्रॉक्सी. उदाहरण के लिए, नीचे दी गईassignMessage नीति इसे अनुरोध:

<AssignMessage async="false" continueOnError="false" enabled="true" name="GetURIPath">
 <DisplayName>GetQP</DisplayName>
  <Set>
   <Payload contentType="text/xml">
    <ExtractQP1>{queryinfo.firstWeather}</ExtractQP1>
    <ExtractQP2>{queryinfo.secondWeather}</ExtractQP2>
   </Payload>
  </Set>
  <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
  <AssignTo createNew="false" transport="http" type="request"/>
</AssignMessage>

हेडर

<ExtractVariables name='ExtractVariable-OauthToken'>
  <Source>request</Source>
  <Header name="Authorization">
    <Pattern ignoreCase="false">Bearer {oauthtoken}</Pattern>
  </Header>
  <VariablePrefix>clientrequest</VariablePrefix>
  <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
</ExtractVariables>

मान लीजिए कि आपका एपीआई, OAuth v2.0 बेयरर टोकन का इस्तेमाल करता है. ऊपर दिए गए नीति कोड का नमूना देखें वह OAuth v2.0 टोकन वाले अनुरोध के साथ काम करते हैं, जिसमें इस तरह का हेडर होता है: Authorization: Bearer TU08xptfFfeM7aS0xHqlxTgEAdAM. अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है

एपीआई डिज़ाइनर के तौर पर, मान लें कि आपको टोकन वैल्यू का इस्तेमाल करना है, लेकिन पूरी हेडर) को कैश मेमोरी में सेव करें. आप ऊपर दिए गए ExtractVariables नीति कोड का इस्तेमाल इनके लिए कर सकते हैं: एक्सट्रैक्ट करने के लिए.

जब Apigee Edge इस हेडर के ऊपर ExtractVariables नीति कोड को लागू करता है, तो यह वैरिएबल clientrequest.oauthtoken को इस पर सेट करें TU08xptfFfeM7aS0xHqlxTgEAdAM.

अब आपके पास यहां वैरिएबल clientrequest.oauthtoken को ऐक्सेस करने का विकल्प है: प्रॉक्सी. उदाहरण के लिए, नीचे दी गईassignMessage नीति इसे अनुरोध:

<AssignMessage async="false" continueOnError="false" enabled="true" name="GetURIPath">
 <DisplayName>GetHeader</DisplayName>
  <Set>
   <Payload contentType="text/xml">
    <ExtractHeader>{clientrequest.oauthtoken}</ExtractHeader>
   </Payload>
  </Set>
  <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
  <AssignTo createNew="false" transport="http" type="request"/>
</AssignMessage>

JSON

<ExtractVariables name="ExtractVariables-3">
   <Source>response</Source>
   <JSONPayload>
      <Variable name="latitude" type="float">
         <JSONPath>$.results[0].geometry.location.lat</JSONPath>
      </Variable>
      <Variable name="longitude" type="float">
         <JSONPath>$.results[0].geometry.location.lng</JSONPath>
      </Variable>
   </JSONPayload>
   <VariablePrefix>geocoderesponse</VariablePrefix>
</ExtractVariables>
<JSONPayload>$

इस JSON रिस्पॉन्स पेलोड को ध्यान में रखें:

{
  "results": [{
    "geometry": {
      "location": {
        "lat": 37.42291810,
        "lng": -122.08542120
      },
      "location_type": "ROOFTOP",
      "viewport": {
        "northeast": {
          "lat": 37.42426708029149,
          "lng": -122.0840722197085
        },
        "southwest": {
          "lat": 37.42156911970850,
          "lng": -122.0867701802915
        }
      }
    }
  }]
}

जब Apigee Edge, इस JSON मैसेज के लिए ऊपर मौजूद ExtractVariables नीति कोड को लागू करता है, तो दो वैरिएबल सेट करता है: geocoderesponse.latitude और geocoderesponse.longitude. दोनों वैरिएबल एक जैसे वैरिएबल प्रीफ़िक्स का इस्तेमाल करते हैं geocoderesponse. इन वैरिएबल के लिए सफ़िक्स, साफ़ तौर पर <Variable> एलिमेंट का name एट्रिब्यूट.

वैरिएबल geocoderesponse.latitude को मान मिलता है 37.42291810. वैरिएबल geocoderesponse.longitude को मान मिलता है -122.08542120.

अब आपके पास यहां वैरिएबल geocoderesponse.latitude को ऐक्सेस करने का विकल्प है: प्रॉक्सी. उदाहरण के लिए, नीचे दी गई AssignmentsMessage नीति इसे "अक्षांश" नाम के हेडर में कॉपी करती है इस जवाब में:

<AssignMessage async="false" continueOnError="false" enabled="true" name="GetURIPath">
  <DisplayName>GetJSONVar</DisplayName>
  <Add>
    <Headers>
      <Header name="latitude">{geocoderesponse.latitude}</Header>
    </Headers>
  </Add> 
  <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
  <AssignTo createNew="false" transport="http" type="response"/> 
</AssignMessage>

XML

<ExtractVariables name="ExtractVariables-4">
   <Source>response</Source>
   <XMLPayload>
      <Namespaces>
         <Namespace prefix="dir">urn:43BFF88D-D204-4427-B6BA-140AF393142F</Namespace>
      </Namespaces>
      <Variable name="travelmode" type="string">
         <XPath>/dir:Directions/dir:route/dir:leg/dir:step/@mode</XPath>
      </Variable>
      <Variable name="duration" type="string">
         <XPath>/dir:Directions/dir:route/dir:leg/dir:step/dir:duration/dir:value</XPath>
      </Variable>
      <Variable name="timeunit" type="string">
         <XPath>/dir:Directions/dir:route/dir:leg/dir:step/dir:duration/dir:text</XPath>
      </Variable>
   </XMLPayload>
   <VariablePrefix>directionsresponse</VariablePrefix>
</ExtractVariables>
<XMLPayload>

इस एक्सएमएल रिस्पॉन्स पेलोड पर विचार करें:

<Directions xmlns="urn:43BFF88D-D204-4427-B6BA-140AF393142F">
   <status>OK</status>
   <route>
      <summary>I-40 W</summary>
      <leg>
         <step mode="DRIVING">
            <start_location>
               <lat>41.8507300</lat>
               <lng>-87.6512600</lng>
            </start_location>
            <end_location>
               <lat>41.8525800</lat>
               <lng>-87.6514100</lng>
            </end_location>
            <duration>
                <value>19</value>
                <text>minutes</text>
            </duration>
         </step>
      </leg>
   </route>
</Directions>

जब Apigee Edge इस एक्सएमएल मैसेज के ऊपर, ExtractVariables नीति कोड को लागू करता है, तो वह तीन वैरिएबल सेट करता है: directionsresponse.travelmode, directionsresponse.duration और directionsresponse.timeunit. सभी वैरिएबल directionsresponse के समान वैरिएबल प्रीफ़िक्स का इस्तेमाल करते हैं. इसके लिए प्रत्यय ये वैरिएबल साफ़ तौर पर <Variable> एलिमेंट के ज़रिए तय किए जाते हैं name एट्रिब्यूट की वैल्यू सबमिट करें.

वैरिएबल directionsresponse.travelmode को मान मिलता है DRIVING. वैरिएबल directionsresponse.duration को मान मिलता है 19. वैरिएबल directionsresponse.timeunit को मान मिलता है minutes.

अब आप यहां से directionresponse.travelmode वैरिएबल को ऐक्सेस कर सकते हैं आपका प्रॉक्सी. उदाहरण के लिए, नीचे दी गई AssignmentsMessage नीति, इसे हेडर में कॉपी करती है "tmode" इस जवाब में:

<AssignMessage async="false" continueOnError="false" enabled="true" name="GetURIPath">
  <DisplayName>GetXMLVar</DisplayName>
  <Add>
    <Headers>
      <Header name="tmode">{directionsresponse.travelmode}</Header>
    </Headers>
  </Add>
  <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
  <AssignTo createNew="false" transport="http" type="request"/>
</AssignMessage>
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है

ExtractVariables नीति के बारे में

एपीआई डेवलपर, एपीआई प्रॉक्सी बनाते हैं, जो मैसेज के कॉन्टेंट के आधार पर अलग-अलग तरह से काम करते हैं, इसमें हेडर, यूआरआई पाथ, पेलोड, और क्वेरी पैरामीटर शामिल हैं. अक्सर, प्रॉक्सी सर्वर इस कॉन्टेंट का एक हिस्सा है. यह करने के लिए ExtractVariables नीति का इस्तेमाल करें यह.

ExtractVariables नीति को तय करते समय, आप ये चुन सकते हैं:

  • सेट किए जाने वाले वैरिएबल के नाम
  • वैरिएबल का सोर्स
  • कितने वैरिएबल एक्सट्रैक्ट और सेट करने हैं

लागू होने पर, यह नीति, कॉन्टेंट पर एक टेक्स्ट पैटर्न लागू करती है. साथ ही, मिलता-जुलता पैटर्न मिलने पर, यह नीति सेट कर देती है कॉन्टेंट के साथ तय किए गए वैरिएबल की वैल्यू. इसके बाद, अन्य नीतियों और कोड का इस्तेमाल किया जा सकता है उन वैरिएबल का इस्तेमाल करके डाइनैमिक बिहेवियर को चालू किया जा सकता है या कारोबार का डेटा Edge API Analytics को भेजा जा सकता है.

कॉन्टेंट पर आधारित Analytics रिपोर्ट बनाने के लिए, ExtractVariables का इस्तेमाल करने का तरीका जानने के लिए, देखें विश्लेषण करें एपीआई मैसेज का कॉन्टेंट, जो कस्टम ऐनलिटिक्स का इस्तेमाल करता हो.

दायरा

ExtractVariables नीति के साथ सेट किए गए वैरिएबल का ग्लोबल स्कोप होता है. इसका मतलब है कि ExtractVariables की नीति एक नए वैरिएबल के बारे में बताती है, तो आप उस वैरिएबल को किसी भी नीति से ऐक्सेस कर सकते हैं या कोड को फ़्लो के किसी भी चरण में डालें (जो ExtractVariables नीति के बाद एक्ज़ीक्यूट करता है). यह शामिल हैं:

  • PreFlow: ProxyEndpoint और TargetEndpoint (अनुरोध और जवाब)
  • PostFlow: ProxyEndpoint और TargetEndpoint (अनुरोध और जवाब)
  • PostClientFlow: ProxyEndpoint (सिर्फ़ रिस्पॉन्स के लिए, मैसेज लॉग करने की नीति)
  • गड़बड़ी का फ़्लो

मैचिंग और वैरिएबल बनाने के बारे में जानकारी

ExtractVariables नीति किसी अनुरोध या जवाब से जानकारी निकालती है और लिखती है कि जानकारी को वैरिएबल में बदला जा सकता है. एक्सट्रैक्ट की जा सकने वाली हर तरह की जानकारी के लिए, जैसे कि यूआरआई पाथ या एक्सएमएल डेटा का इस्तेमाल करके, इकट्ठा की गई जानकारी.

हालांकि, पैटर्न मैचिंग के काम करने का तरीका, एक्सट्रैक्शन के सोर्स पर निर्भर करता है. नीचे दिए गए सेक्शन में, जानकारी की दो बुनियादी कैटगरी के बारे में बताया गया है, जिसे एक्सट्रैक्ट किया जा सकता है.

मिलते-जुलते यूआरआई पाथ, क्वेरी पैरामीटर, हेडर, फ़ॉर्म पैरामीटर, और वैरिएबल

यूआरआई पाथ, क्वेरी पैरामीटर, हेडर, फ़ॉर्म पैरामीटर, और वैरिएबल, जिनके लिए आप एक या उससे ज़्यादा की वैल्यू तय करने के लिए, &lt;Pattern&gt; टैग का इस्तेमाल करते हैं मिलान करने के लिए पैटर्न. उदाहरण के लिए, नीति का यह उदाहरण यूआरआई पाथ:

<ExtractVariables name="ExtractVariables-1">
   <Source>request</Source>
   <URIPath>
      <Pattern ignoreCase="true">/a/{pathSeg}</Pattern>
   </URIPath>
   <VariablePrefix>urirequest</VariablePrefix>
   <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
</ExtractVariables>

इस उदाहरण में, urirequest.pathSeg वैरिएबल सेट किया गया है जो भी प्रॉक्सी.pathsuffix में "/a/" के बाद दिखाई देती है. उदाहरण के लिए, मान लें कि आपका एपीआई प्रॉक्सी /basepath/v1 है . इनबाउंड अनुरोध के साथ http://myCo.com/basepath/v1/a/b पर वैरिएबल को "b" पर सेट किया गया है.

एक से ज़्यादा पैटर्न तय करना

&lt;Pattern&gt; टैग के हिसाब से, मैच करने के लिए कई पैटर तय किए जा सकते हैं, जहां:

  • मैच के लिए सभी पैटर्न की जांच की जाती है.
  • अगर कोई भी पैटर्न मैच नहीं करता है, तो नीति कुछ भी नहीं करती है और वैरिएबल बनाया गया.
  • यदि एक से अधिक पैटर्न मेल खाते हैं, तो सबसे लंबे पथ सेगमेंट वाले पैटर्न का उपयोग एक्सट्रैक्शन.
  • यदि मेल खाने वाले दो पैटर्न में एक समान सबसे लंबे पथ सेगमेंट हैं, तो इस नीति का इस्तेमाल एक्सट्रैक्ट करने के लिए किया जाता है.

अगले उदाहरण में, एक ऐसी नीति बनाई गई है जिसमें यूआरआई के तीन मिलते-जुलते पैटर्न शामिल हैं पथ:

<ExtractVariables name="ExtractVariables-1">
   <Source>request</Source>
   <URIPath>
      <Pattern ignoreCase="true">/a/{pathSeg}</Pattern>
      <Pattern ignoreCase="true">/a/b/{pathSeg}</Pattern>
      <Pattern ignoreCase="true">/a/b/c/{pathSeg}</Pattern>
   </URIPath>
   <VariablePrefix>urirequest</VariablePrefix>
   <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
</ExtractVariables>

मान लीजिए कि /basepath/v1 के बेसपाथ वाले एपीआई प्रॉक्सी के लिए, इनबाउंड अनुरोध यूआरएल की सेटिंग इस तरह की होती है:

http://myCo.com/basepath/v1/a/b

इस उदाहरण में, पहला पैटर्न, यूआरआई से मैच करता है और urirequest.pathSeg वैरिएबल है "b" पर सेट होना चाहिए.

अगर अनुरोध किया जाने वाला यूआरएल यह है:

http://myCo.com/basepath/v1/a/b/c/d

...फिर तीसरा पैटर्न मैच करता है और urirequest.pathSeg वैरिएबल होता है "d" पर सेट है.

एक से ज़्यादा वैरिएबल वाले पैटर्न तय करना

मैच करने वाले पैटर्न में, एक से ज़्यादा वैरिएबल तय किए जा सकते हैं. उदाहरण के लिए, आपने दो वैरिएबल वाला मैचिंग पैटर्न:

<ExtractVariables name="ExtractVariables-1">
   <Source>request</Source>
   <URIPath>
      <Pattern ignoreCase="true">/a/{pathSeg}</Pattern>
      <Pattern ignoreCase="true">/a/b/{pathSeg}</Pattern>
      <Pattern ignoreCase="true">/a/{pathSeg1}/c/{pathSeg2}</Pattern>
   </URIPath>
   <VariablePrefix>urirequest</VariablePrefix>
   <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
</ExtractVariables>

इनबाउंड अनुरोध के लिए , फिर से /basepath/v1 के बेस पाथ के साथ एपीआई प्रॉक्सी दिखाना यूआरएल:

http://myCo.com/basepath/v1/a/b/c/d

...urirequest.pathSeg1 वैरिएबल है "b" पर सेट किया गया और urirequest.pathSeg2 वैरिएबल है "d" पर सेट है.

पैटर्न में एक से ज़्यादा इंस्टेंस का मिलान करना

एक ही नाम वाले किसी आइटम के एक से ज़्यादा इंस्टेंस होने पर भी पैटर्न का मिलान किया जा सकता है. उदाहरण के लिए, ऐसा अनुरोध किया जा सकता है जिसमें एक से ज़्यादा क्वेरी पैरामीटर या एक से ज़्यादा हेडर हों पर क्लिक करें. नीचे दिए गए अनुरोध में "w" नाम के दो क्वेरी पैरामीटर शामिल हैं:

http://myCo.com/basepath/v1/a/b/c/d?w=1&w=2

ExtractVariables नीति में इन क्वेरी पैरामीटर का रेफ़रंस देने के लिए, इंडेक्स का इस्तेमाल करें, जहां क्वेरी पैरामीटर के पहले इंस्टेंस में कोई इंडेक्स नहीं है, दूसरा इंडेक्स 2 पर, तीसरा इंडेक्स 3 वगैरह का एक उदाहरण है. उदाहरण के लिए, नीचे दी गई नीति दूसरे क्वेरी पैरामीटर की वैल्यू को एक्सट्रैक्ट करती है नाम "w" अनुरोध में:

<ExtractVariables name="ExtractVariables-1">
   <Source>request</Source>
   <QueryParam name="w.2">
      <Pattern ignoreCase="true">{secondW}</Pattern>
   </QueryParam>
   <VariablePrefix>urirequest</VariablePrefix>
   <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
</ExtractVariables>

urirequest.secondW वैरिएबल यह है "2" पर सेट करें. अगर अनुरोध में दूसरा क्वेरी पैरामीटर शामिल नहीं किया जाता है, तो urirequest.secondW वैरिएबल खाली. अगर अनुरोध में एक ही नाम वाले कई आइटम हैं, तो उन्हें इंडेक्स करने की सुविधा का इस्तेमाल करें.

पैटर्न में विशेष वर्णों का इस्तेमाल करना

यूआरआई पाथ का मिलान करते समय, "*" का इस्तेमाल किया जा सकता है और "**" पैटर्न में वाइल्डकार्ड वर्ण, कहां:

  • "*" पाथ के किसी एक सेगमेंट से मेल खाता हो
  • "**" पाथ के एक से ज़्यादा सेगमेंट से मेल खाता है

उदाहरण के लिए, &lt;URIPath&gt; एलिमेंट के पैटर्न बताए गए हैं, जैसा कि दिखाया गया है नीचे दिया गया है:

<URIPath>
  <Pattern ignoreCase="true">/a/*/{id}</Pattern>
  <Pattern ignoreCase="true">/a/**/{id}</Pattern>
</URIPath>

पहला पैटर्न, पाथफ़ीक्स वाले अनुरोधों से मेल खाता है (जो नीचे दिए गए यूआरआई पाथ का हिस्सा है (बेसपाथ) जैसे "/a/b/c", "/a/foo/bar" वगैरह. दूसरा पैटर्न कितने भी पाथ से मेल खाता है "/a/" के बाद सेगमेंट, जैसे कि "/a/foo/bar/baz/c" और "/a/b/c" और "/a/foo/bar".

क्वेरी पैरामीटर, हेडर, और फ़ॉर्म पैरामीटर में पैटर्न तय करते समय, "*" वर्ण वर्णों की किसी भी संख्या से मिलान करने के लिए निर्दिष्ट करता है. उदाहरण के लिए, हेडर का मिलान करते समय, पैटर्न इस रूप में:

*;charset={encoding}

यह पैटर्न "text/xml;charset=UTF-16" वैल्यू से मेल खाता है और "application/xml;charset=ASCII".

अगर ExtractVariables नीति में पास की गई वैल्यू में एक खास वर्ण है, जैसे "{", "%" इस्तेमाल करें वर्ण शामिल करें. नीचे दिए गए उदाहरण में "{" और "}" वर्ण पैटर्न में बदल सकते हैं, क्योंकि उनका इस्तेमाल क्वेरी की वैल्यू में लिटरल वर्णों के तौर पर किया जाता है पैरामीटर:

<QueryParam>
  <Pattern ignoreCase="true">%{user%} {name}</Pattern>
</QueryParam>

इस उदाहरण में, पैटर्न "{user} स्टीव" से मेल खाता है लेकिन "उपयोगकर्ता" स्टीव".

JSON और एक्सएमएल से मिलता-जुलता

JSON और XML से डेटा एक्सट्रैक्ट करते समय, आप नीति में एक या उससे ज़्यादा &lt;Variable&gt; टैग तय करते हैं. &lt;Variable&gt; टैग उस डेस्टिनेशन वैरिएबल का नाम जहां निकाली गई जानकारी सेव की जाती है और JsonPath (JSON) या XPATH (एक्सएमएल) को एक्सट्रैक्ट किया जाएगा.

नीति में मौजूद सभी &lt;Variable&gt; टैग का मूल्यांकन किया जाता है, ताकि आप एक ही नीति से कई वैरिएबल पॉप्युलेट कर सकें. अगर आपने &lt;Variable&gt; टैग JSON या XML के किसी मान्य फ़ील्ड में मूल्यांकन करते हैं, तो संबंधित वैरिएबल नहीं होता है बनाया गया.

इस उदाहरण में, ExtractVariables की नीति को दिखाया गया है जो किसी जवाब का JSON मुख्य हिस्सा:

<ExtractVariables name="ExtractVariables-3">
   <Source>response</Source>
   <JSONPayload>
      <Variable name="latitude" type="float">
         <JSONPath>$.results[0].geometry.location.lat</JSONPath>
      </Variable>
      <Variable name="longitude" type="float">
         <JSONPath>$.results[0].geometry.location.lng</JSONPath>
      </Variable>
   </JSONPayload>
   <VariablePrefix>geocoderesponse</VariablePrefix>
</ExtractVariables>

इसमें कई जगहों पर एक ही वैरिएबल

सेट करने के लिए वैरिएबल के नाम चुनते समय सावधानी बरतें. नीति, क्रम से एक्सट्रैक्शन पैटर्न से अंतिम तक. अगर नीति, किसी वैरिएबल पर कई जगहों पर डाला गया है, तो नीति में आखिरी बार लिखा गया वैरिएबल, वैरिएबल की वैल्यू तय करता है. (यह जो आपको चाहिए.)

उदाहरण के लिए, आपको ऐसी टोकन वैल्यू एक्सट्रैक्ट करनी है जिसे क्वेरी पैरामीटर में पास किया जा सके हेडर में दिखेगी, जैसा कि नीचे दिखाया गया है:

<!-- If token only in query param, the query param determines the value. 
     If token is found in both the query param and header, header sets value. -->
<QueryParam name="token">
  <Pattern ignoreCase="true">{tokenValue}</Pattern>
</QueryParam>
 
<!-- Overwrite tokenValue even if it was found in query parameter. -->
<Header name="Token">
  <Pattern ignoreCase="true">{tokenValue}</Pattern>
</Header>

यह तय करना कि कोई मैच न होने पर क्या होता है

अगर पैटर्न मेल नहीं खाता है, तो संबंधित वैरिएबल नहीं बनाया जाता है. इसलिए, अगर कोई दूसरी नीति वैरिएबल का रेफ़रंस देती है, तो इससे गड़बड़ी हो सकती है.

एक विकल्प यह है कि <IgnoreUnresolvedVariables> को इस पर सेट किया जाए 'सही' पर सेट करें, जो ट्रीटमेंट के लिए नीति को कॉन्फ़िगर करने के लिए, वैरिएबल का रेफ़रंस देती है खाली स्ट्रिंग (शून्य) के तौर पर, ऐसा कोई वैरिएबल जिसे हल नहीं किया जा सकता:

<IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>

एलिमेंट का रेफ़रंस

एलिमेंट का रेफ़रंस, ExtractVariables के एलिमेंट और एट्रिब्यूट के बारे में बताता है की नीति देखें.

<ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1">
   <DisplayName>Extract Variables 1</DisplayName>
   <Source clearPayload="true|false">request</Source>
   <VariablePrefix>myprefix</VariablePrefix>
   <IgnoreUnresolvedVariables>true|false</IgnoreUnresolvedVariables>
   <URIPath>
      <Pattern ignoreCase="false">/accounts/{id}</Pattern>
   </URIPath>
   <QueryParam name="code">
      <Pattern ignoreCase="true">DBN{dbncode}</Pattern>
   </QueryParam>
   <Header name="Authorization">
      <Pattern ignoreCase="false">Bearer {oauthtoken}</Pattern>
   </Header>
   <FormParam name="greeting">
      <Pattern>hello {user}</Pattern>
   </FormParam>
   <Variable name="request.content">
       <Pattern>hello {user}</Pattern>
   </Variable>
   <JSONPayload>
      <Variable name="name">
         <JSONPath>{example}</JSONPath>
      </Variable>
   </JSONPayload>
   <XMLPayload stopPayloadProcessing="false">
      <Namespaces/>
      <Variable name="name" type="boolean">
         <XPath>/test/example</XPath>
      </Variable>
   </XMLPayload>
</ExtractVariables>

&lt;ExtractVariables&gt; एट्रिब्यूट

<ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1">

यहां दी गई टेबल में, ऐसे एट्रिब्यूट के बारे में बताया गया है जो नीति के सभी पैरंट एलिमेंट में एक जैसे होते हैं:

एट्रिब्यूट ब्यौरा डिफ़ॉल्ट मौजूदगी
name

नीति का अंदरूनी नाम. name एट्रिब्यूट की वैल्यू ये काम कर सकती है: अक्षरों, संख्याओं, स्पेस, हाइफ़न, अंडरस्कोर, और फ़ुलस्टॉप को शामिल करें. यह मान नहीं हो सकता 255 वर्णों से ज़्यादा होने चाहिए.

इसके अलावा, नीति को लेबल करने के लिए, <DisplayName> एलिमेंट का इस्तेमाल करें प्रबंधन यूज़र इंटरफ़ेस (यूआई) प्रॉक्सी एडिटर को अलग, आम भाषा में इस्तेमाल करने वाले नाम के साथ किया जा सकता है.

लागू नहीं ज़रूरी है
continueOnError

किसी नीति के काम न करने पर, गड़बड़ी दिखाने के लिए false पर सेट करें. यह उम्मीद है व्यवहार की जानकारी देने वाला डेटा.

नीति के लागू होने के बाद भी फ़्लो को एक्ज़ीक्यूट करने के लिए, इसे true पर सेट करें विफल होता है.

गलत वैकल्पिक
enabled

नीति को लागू करने के लिए, true पर सेट करें.

नीति को बंद करने के लिए, false पर सेट करें. नीति लागू किया जाता है, भले ही वह किसी फ़्लो से जुड़ा रहता हो.

सही वैकल्पिक
async

यह एट्रिब्यूट अब काम नहीं करता.

गलत बहिष्कृत

&lt;DisplayName&gt; एलिमेंट

इस कॉलम में नीति को लेबल करने के लिए, name एट्रिब्यूट के साथ-साथ इस्तेमाल करें मैनेजमेंट यूज़र इंटरफ़ेस (यूआई) प्रॉक्सी एडिटर, जिसका नाम अलग और सामान्य भाषा में है.

<DisplayName>Policy Display Name</DisplayName>
डिफ़ॉल्ट

लागू नहीं

अगर आप इस एलिमेंट को छोड़ देते हैं, तो नीति की name एट्रिब्यूट की वैल्यू यह होगी इस्तेमाल किया गया.

मौजूदगी वैकल्पिक
टाइप स्ट्रिंग

&lt;Source&gt; एलिमेंट

(ज़रूरी नहीं) पार्स किए जाने वाले वैरिएबल के बारे में बताता है. मान <Source> की डिफ़ॉल्ट वैल्यू message है. message वैल्यू कॉन्टेक्स्ट के हिसाब से सही है. अनुरोध की प्रोसेस में, message अनुरोध वाले मैसेज का जवाब देता है. तय सीमा में रिस्पॉन्स फ़्लो में, message रिस्पॉन्स मैसेज तक पहुंचाता है.

वैसे तो आप किसी अनुरोध या जवाब वाले मैसेज से जानकारी निकालने के लिए अक्सर इस नीति का इस्तेमाल करते हैं, लेकिन आप इसका इस्तेमाल करके, किसी भी वैरिएबल से जानकारी ली जा सकती है. उदाहरण के लिए, इसे एक्सट्रैक्ट करने के लिए इस्तेमाल किया जा सकता है AccessEntity नीति के तहत बनाई गई इकाई की जानकारी (डेटा से ली गई जानकारी) सेवा के ज़रिए लौटाया गया कॉलआउट नीति का इस्तेमाल करें या किसी एक्सएमएल या JSON ऑब्जेक्ट से जानकारी निकालें.
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है अगर <Source> ठीक नहीं किया जा सकता या उसके लिए ऐसे मैसेज का इस्तेमाल किया जाता है जो मैसेज नहीं है, नीति लागू नहीं हो पाएगी.

<Source clearPayload="true|false">request</Source>
डिफ़ॉल्ट: मैसेज
मौजूदगी: वैकल्पिक
टाइप: स्ट्रिंग

विशेषताएं

एट्रिब्यूट ब्यौरा डिफ़ॉल्ट मौजूदगी टाइप
clearPayload

अगर आपको इसमें बताए गए पेलोड को हटाना है, तो true पर सेट करें &lt;Source&gt; उससे डेटा एक्सट्रैक्ट करने के बाद.
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है <clearPayload> विकल्प का इस्तेमाल सिर्फ़ तब करें, जब सोर्स मैसेज ऐसा न हो ExtractVariables के इस्तेमाल करने के बाद ज़रूरी है. true पर सेट करने से मुफ़्त आ जाता है मैसेज में इस्तेमाल की गई मेमोरी बढ़ाएं.

गलत

वैकल्पिक बूलियन

&lt;VariablePrefix&gt; एलिमेंट

(ज़रूरी नहीं) वैरिएबल का पूरा नाम इस तरह बनाया जाता है: <VariablePrefix>, एक बिंदु, और वह नाम जिसे आपने {curly braces} में <Pattern> एलिमेंट या &lt;Variable&gt; एलिमेंट. जैसे: myprefix.id, myprefix.dbncode या myprefix.oauthtoken.

<VariablePrefix>myprefix</VariablePrefix>

उदाहरण के लिए, मान लें कि नाम की वैल्यू "उपयोगकर्ता" है.

  • अगर <VariablePrefix> तय नहीं किया गया है, तो निकाले गए मान user नाम वाले वैरिएबल को असाइन किया गया है.
  • यदि <VariablePrefix> को myprefix के रूप में दिखाया गया है, तो एक्सट्रैक्ट किए गए वैल्यू, myprefix.user नाम के वैरिएबल को असाइन की जाती हैं.
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: वैकल्पिक
टाइप: स्ट्रिंग

&lt;IgnoreUnresolvedVariables&gt; एलिमेंट

(ज़रूरी नहीं) किसी भी ऐसे वैरिएबल को खाली स्ट्रिंग के तौर पर ट्रीट करने के लिए true पर सेट करें जिसे रिज़ॉल्व नहीं किया जा सकता (शून्य). अगर आपको यह सेट करना है कि किसी रेफ़रंस में बताए गए समय पर, नीति के तहत गड़बड़ी दिखे, तो उसे false पर सेट करें वैरिएबल को ठीक नहीं किया जा सकता.

<IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
डिफ़ॉल्ट: गलत
मौजूदगी: वैकल्पिक
टाइप: बूलियन

अगर <XMLPayload> में कोई OAuth रेफ़रंस ठीक नहीं किया गया है, तो नीति यह गड़बड़ी दिख रही है:

{
   "fault":{
      "faultstring":"Unresolved xpath path in policy policy_name.",
      "detail":{
         "errorcode":"steps.extractvariables.InvalidXPath"
      }
   }
}

&lt;URIPath&gt; एलिमेंट

(ज़रूरी नहीं है. ज़्यादा जानकारी के लिए, नीचे दी गई टेबल में 'मौजूदगी' लाइन देखें.) कोई वैल्यू एक्सट्रैक्ट करता है अनुरोध स्रोत मैसेज की प्रॉक्सी.pathsuffix से निकालें. पाथ इस पर लागू किया गया पैटर्न प्रॉक्सी है.pathsuffix, जिसमें एपीआई प्रॉक्सी का बेसपाथ शामिल नहीं है. अगर आपने सोर्स मैसेज में जवाब देने वाला मैसेज टाइप हो जाता है, फिर यह एलिमेंट कुछ नहीं करता.

<URIPath>
   <Pattern ignoreCase="false">/accounts/{id}</Pattern>
</URIPath>

एक से ज़्यादा &lt;Pattern&gt; एलिमेंट इस्तेमाल किए जा सकते हैं:

<URIPath>
   <Pattern ignoreCase="false">/accounts/{id}</Pattern>
   <Pattern ignoreCase="false">/accounts/{id}/transactions/{index}</Pattern>
</URIPath>
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: ज़रूरी नहीं. हालांकि, आपको इनमें से कम से कम एक को शामिल करना होगा: <URIPath>, <QueryParam>, <Header>, <FormParam>, <JSONPayload> या <XMLPayload>.
टाइप: लागू नहीं

विशेषताएं

एट्रिब्यूट ब्यौरा डिफ़ॉल्ट मौजूदगी टाइप
ignoreCase पैटर्न से मेल खाने पर, केस को अनदेखा करने के बारे में बताता है.

गलत

वैकल्पिक बूलियन

&lt;QueryParam&gt; एलिमेंट

(ज़रूरी नहीं है. ज़्यादा जानकारी के लिए, नीचे दी गई टेबल में 'मौजूदगी' लाइन देखें.) कोई वैल्यू एक्सट्रैक्ट करता है अनुरोध सोर्स मैसेज के चुने गए क्वेरी पैरामीटर से अगर सोर्स मैसेज में रिस्पॉन्स शामिल होता है. इसके बाद, यह एलिमेंट इस तरह का काम करता है: कुछ नहीं.

<QueryParam name="code">
   <Pattern ignoreCase="true">DBN{dbncode}</Pattern>
</QueryParam>

अगर कई क्वेरी पैरामीटर के नाम एक जैसे हैं, तो पैरामीटर के बारे में बताने के लिए इंडेक्स का इस्तेमाल करें:

<QueryParam name="w.2">
   <Pattern ignoreCase="true">{secondW}</Pattern>
</QueryParam>
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: ज़रूरी नहीं. हालांकि, आपको इनमें से कम से कम एक को शामिल करना होगा: <URIPath>, <QueryParam>, <Header>, <FormParam>, <JSONPayload> या <XMLPayload>.
टाइप: लागू नहीं

विशेषताएं

एट्रिब्यूट ब्यौरा डिफ़ॉल्ट मौजूदगी टाइप
नाम क्वेरी पैरामीटर का नाम बताता है. अगर कई क्वेरी पैरामीटर में समान नाम, इंडेक्स किए गए संदर्भ का इस्तेमाल करें, जहां क्वेरी पैरामीटर का पहला इंस्टेंस इसमें कोई इंडेक्स नहीं है, दूसरा इंडेक्स 2 पर, तीसरा इंडेक्स 3 पर वगैरह.

लागू नहीं

ज़रूरी है स्ट्रिंग

&lt;Header&gt; एलिमेंट

(ज़रूरी नहीं है. ज़्यादा जानकारी के लिए, नीचे दी गई टेबल में 'मौजूदगी' लाइन देखें.) कोई वैल्यू एक्सट्रैक्ट करता है तय किए गए अनुरोध या जवाब मैसेज के बताए गए एचटीटीपी हेडर से. अगर एक से ज़्यादा हेडर में एक जैसा नाम देते हैं, तो उनकी वैल्यू एक कलेक्शन में स्टोर रहती हैं.

<!-- The name is the actual header name. -->
<Header name="Authorization">
<!-- Provide a name for your new custom variable here. -->
   <Pattern ignoreCase="false">Bearer {oauthtoken}</Pattern>
</Header>

अगर कई हेडर के नाम एक जैसे हैं, तो अलग-अलग हेडर का रेफ़रंस देने के लिए इंडेक्स का इस्तेमाल करें कलेक्शन:

<Header name="myHeader.2">
   <Pattern ignoreCase="true">{secondHeader}</Pattern>
</Header>

या अरे में सभी हेडर लिस्ट करने के लिए नीचे दिया गया तरीका अपनाएं:

<Header name="myHeader.values">
   <Pattern ignoreCase="true">{myHeaders}</Pattern>
</Header>
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: ज़रूरी नहीं. हालांकि, आपको इनमें से कम से कम एक को शामिल करना होगा: <URIPath>, <QueryParam>, <Header>, <FormParam>, <JSONPayload> या <XMLPayload>.
टाइप: लागू नहीं

विशेषताएं

एट्रिब्यूट ब्यौरा डिफ़ॉल्ट मौजूदगी टाइप
नाम उस हेडर का नाम बताता है जिससे वैल्यू एक्सट्रैक्ट की जाती है. अगर एक से ज़्यादा हेडर का नाम समान हो, तो इंडेक्स किए गए रेफ़रंस का इस्तेमाल करें, जहां हेडर का पहला इंस्टेंस हेडर में कोई इंडेक्स नहीं है, दूसरा इंडेक्स 2 पर, तीसरा इंडेक्स 3 पर, वगैरह. इस्तेमाल करें कलेक्शन में सभी हेडर पाने के लिए .values.

लागू नहीं

ज़रूरी है स्ट्रिंग

&lt;FormParam&gt; एलिमेंट

(ज़रूरी नहीं है. ज़्यादा जानकारी के लिए, नीचे दी गई टेबल में 'मौजूदगी' लाइन देखें.) कोई वैल्यू एक्सट्रैक्ट करता है बताए गए अनुरोध या जवाब मैसेज के बताए गए फ़ॉर्म पैरामीटर से. फ़ॉर्म पैरामीटर सिर्फ़ तब निकाला जा सकता है, जब तय किए गए मैसेज का Content-Type हेडर application/x-www-form-urlencoded.

<FormParam name="greeting">
    <Pattern>hello {user}</Pattern>
</FormParam>
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: ज़रूरी नहीं. हालांकि, आपको इनमें से कम से कम एक को शामिल करना होगा: <URIPath>, <QueryParam>, <Header>, <FormParam>, <JSONPayload> या <XMLPayload>.
टाइप: लागू नहीं

विशेषताएं

एट्रिब्यूट ब्यौरा डिफ़ॉल्ट मौजूदगी टाइप
नाम उस फ़ॉर्म पैरामीटर का नाम जिससे वैल्यू एक्सट्रैक्ट की जाती है.

लागू नहीं

ज़रूरी है स्ट्रिंग

&lt;Variable&gt; एलिमेंट

(ज़रूरी नहीं है. ज़्यादा जानकारी के लिए, नीचे दी गई टेबल में 'मौजूदगी' लाइन देखें.) यह बताता है कि उस वैरिएबल का नाम जिससे वैल्यू एक्सट्रैक्ट करनी है.

<Variable name="myVar">
    <Pattern>hello {user}</Pattern>
</Variable>

वैरिएबल से दो वैल्यू एक्सट्रैक्ट करने के लिए:

<Variable name="myVar">
   <Pattern>hello {firstName} {lastName}</Pattern>
</Variable>
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: ज़रूरी नहीं. हालांकि, आपको इनमें से कम से कम एक को शामिल करना होगा: <URIPath>, <QueryParam>, <Header>, <FormParam>, <JSONPayload> या <XMLPayload>.
टाइप: लागू नहीं

विशेषताएं

एट्रिब्यूट ब्यौरा डिफ़ॉल्ट मौजूदगी टाइप
नाम उस वैरिएबल का नाम जिससे वैल्यू एक्सट्रैक्ट करनी है.

लागू नहीं

ज़रूरी है स्ट्रिंग

&lt;JSONPayload&gt; एलिमेंट

(ज़रूरी नहीं है. ज़्यादा जानकारी के लिए, नीचे दी गई टेबल में 'मौजूदगी' लाइन देखें.) यह बताता है कि JSON के फ़ॉर्मैट वाला मैसेज, जिससे वैरिएबल की वैल्यू निकाली जाएगी. JSON एक्सट्रैक्शन सिर्फ़ तब किया जाता है, जब मैसेज का Content-Type हेडर Content-Type हो.

<JSONPayload>
   <Variable name="name" type="string">
      <JSONPath>{example}</JSONPath>
   </Variable>
</JSONPayload>
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: ज़रूरी नहीं. हालांकि, आपको इनमें से कम से कम एक को शामिल करना होगा: <URIPath>, <QueryParam>, <Header>, <FormParam>, <JSONPayload> या <XMLPayload>.
टाइप: लागू नहीं

&lt;JSONPayload&gt;/&lt;Variable&gt; एलिमेंट

(JSONPayload एलिमेंट में ज़रूरी है.) उस वैरिएबल के बारे में बताता है जहां एक्सट्रैक्ट की गई वैल्यू असाइन किया गया है. जानकारी अपने-आप भरने के लिए, &lt;Variable&gt; एलिमेंट में कई &lt;Variable&gt; टैग शामिल किए जा सकते हैं सेट करें.

<Variable name="name" type="string">
   <JSONPath>{example}</JSONPath>
</Variable>
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: JSONPayload एलिमेंट में ज़रूरी है.
टाइप: लागू नहीं

विशेषताएं

एट्रिब्यूट ब्यौरा डिफ़ॉल्ट मौजूदगी टाइप
नाम

उस वैरिएबल का नाम तय करता है जिस पर एक्सट्रैक्ट किया गया मान मिलेगा असाइन किया गया है.

नाम

ज़रूरी है स्ट्रिंग
टाइप इससे वैरिएबल वैल्यू के डेटा टाइप की जानकारी मिलती है. लागू नहीं वैकल्पिक

स्ट्रिंग. इनमें से चुनें:

  • स्ट्रिंग
  • बूलियन
  • पूर्णांक
  • लंबा
  • फ़्लोट
  • दोगुनी
  • नोडसेट (JSON फ़्रैगमेंट दिखाता है)

&lt;JSONPayload&gt;/&lt;Variable&gt;/&lt;JSONPath&gt; एलिमेंट

(JSONPayload:Variable एलिमेंट में ज़रूरी है.) एक्सट्रैक्ट करने के लिए इस्तेमाल किया जाने वाला JSON पाथ बताता है JSON के फ़ॉर्मैट वाले मैसेज से ली गई वैल्यू.

<Variable name="name">
   <JSONPath>$.rss.channel.title</JSONPath>
</Variable>
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: ज़रूरी है
टाइप: स्ट्रिंग

&lt;XMLPayload&gt; एलिमेंट

(ज़रूरी नहीं है. ज़्यादा जानकारी के लिए, नीचे दी गई टेबल में 'मौजूदगी' लाइन देखें.) यह बताता है कि एक्सएमएल फ़ॉर्मैट वाला मैसेज, जिससे वैरिएबल की वैल्यू निकाली जाएगी. एक्सएमएल पेलोड सिर्फ़ तब एक्सट्रैक्ट किए जाते हैं, जब मैसेज का Content-Type हेडर होता है है text/xml, application/xml, या application/*+xml.

<XMLPayload stopPayloadProcessing="false">
  <Namespaces>
     <Namespace prefix="apigee">http://www.apigee.com</Namespace>
     <Namespace prefix="gmail">http://mail.google.com</Namespace>
  </Namespaces>
  <Variable name="name" type="boolean">
     <XPath>/apigee:test/apigee:example</XPath>
  </Variable>
</XMLPayload>
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: ज़रूरी नहीं. हालांकि, आपको इनमें से कम से कम एक को शामिल करना होगा: <URIPath>, <QueryParam>, <Header>, <FormParam>, <JSONPayload> या <XMLPayload>.
टाइप: लागू नहीं

विशेषताएं

एट्रिब्यूट ब्यौरा डिफ़ॉल्ट मौजूदगी टाइप
stopPayloadProcessing

एक वैरिएबल के अपने-आप भरने के बाद, OAuth के आकलन को रोकने के लिए, true पर सेट करें. इसका मतलब है कि नीति में सिर्फ़ एक वैरिएबल अपने-आप भरता है.

गलत

वैकल्पिक बूलियन

&lt;XMLPayload&gt;/&lt;Namespaces&gt; एलिमेंट

(ज़रूरी नहीं) यह नेमस्पेस के बारे में बताता है, जिसका इस्तेमाल एक्स पाथ की जांच करने के लिए किया जाना है. अगर इसका इस्तेमाल किया जा रहा है, तो तो आपको यहां नेमस्पेस के बारे में बताना होगा, जैसा कि नीचे दिया गया उदाहरण देखें.

<XMLPayload stopPayloadProcessing="false">
  <Namespaces>
     <Namespace prefix="apigee">http://www.apigee.com</Namespace>
     <Namespace prefix="gmail">http://mail.google.com</Namespace>
  </Namespaces>
  <Variable name="legName" type="string">
    <XPath>/apigee:Directions/apigee:route/apigee:leg/apigee:name</XPath>
  </Variable>
</XMLPayload>

अगर आप अपने+एक्सप्रेशन में नेमस्पेस का इस्तेमाल नहीं कर रहे हैं, तो आप <Namespaces> एलिमेंट, जैसा कि नीचे दिए गए उदाहरण में बताया गया है:

<XMLPayload stopPayloadProcessing="false">
  <!-- <Namespaces/> -->
  <Variable name="legName" type="string">
    <XPath>/Directions/route/leg/name</XPath>
  </Variable>
</XMLPayload>
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: वैकल्पिक
टाइप: स्ट्रिंग

विशेषताएं

एट्रिब्यूट ब्यौरा डिफ़ॉल्ट मौजूदगी टाइप
prefix

नेमस्पेस प्रीफ़िक्स.

लागू नहीं

ज़रूरी है स्ट्रिंग

&lt;XMLPayload&gt;/&lt;Variable&gt; एलिमेंट

(ज़रूरी नहीं) इससे यह वैरिएबल तय होता है कि एक्सट्रैक्ट की गई वैल्यू किस वैरिएबल को असाइन की जाएगी.

<Variable name="name" type="boolean">
   <XPath>/test/example</XPath>
</Variable>
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: वैकल्पिक
टाइप: लागू नहीं

विशेषताएं

एट्रिब्यूट ब्यौरा डिफ़ॉल्ट मौजूदगी टाइप
नाम

उस वैरिएबल का नाम तय करता है जिस पर एक्सट्रैक्ट किया गया मान मिलेगा असाइन किया गया है.

नाम

ज़रूरी है स्ट्रिंग
टाइप इससे वैरिएबल वैल्यू के डेटा टाइप की जानकारी मिलती है. बूलियन वैकल्पिक

स्ट्रिंग. इनमें से चुनें:

  • स्ट्रिंग
  • बूलियन
  • पूर्णांक
  • लंबा
  • फ़्लोट
  • दोगुनी
  • नोडसेट (एक्सएमएल फ़्रैगमेंट दिखाता है)

&lt;XMLPayload&gt;/&lt;Variable&gt;/&lt;XPath&gt; एलिमेंट

(XMLPayload:Variable एलिमेंट के अंदर ज़रूरी है.) यह नीति वैरिएबल. सिर्फ़ OAuth 1.0 एक्सप्रेशन काम करते हैं.

<Variable name="name" type="boolean">
   <XPath>/test/example</XPath>
</Variable>

नेमस्पेस के साथ उदाहरण. अगर आप अपनेएक्स पाथ एक्सप्रेशन में नेमस्पेस का इस्तेमाल करते हैं, तो आपको एलान करना होगा <XMLPayload><Namespaces> सेक्शन में नेमस्पेस नीति के बारे में ज़्यादा जानें.

<Variable name="name" type="boolean">
   <XPath>/foo:test/foo:example</XPath>
</Variable>
डिफ़ॉल्ट: लागू नहीं
मौजूदगी: ज़रूरी है
टाइप: स्ट्रिंग

गड़बड़ी का रेफ़रंस

इस सेक्शन में, गड़बड़ी के कोड और गड़बड़ी के मैसेज के बारे में बताया गया है. साथ ही, इन गड़बड़ियों के वैरिएबल के बारे में भी बताया गया है, जो Edge की मदद से सेट किए जाते हैं. यह जानकारी जानना ज़रूरी है कि क्या आप गड़बड़ियों को ठीक करता है. ज़्यादा जानने के लिए, आपके लिए ज़रूरी जानकारी देखें नीति से जुड़ी गड़बड़ियों और हैंडलिंग के बारे में जानकारी गलतियां.

रनटाइम की गड़बड़ियां

नीति के लागू होने पर ये गड़बड़ियां हो सकती हैं.

गड़बड़ी कोड एचटीटीपी कोड स्थिति वजह ठीक करें
steps.extractvariables.ExecutionFailed 500

यह गड़बड़ी तब होती है, जब:

  • इनपुट पेलोड (JSON, XML) खाली है.
  • नीति में भेजा गया इनपुट (JSON, XML वगैरह) अमान्य या गलत है.
steps.extractvariables.ImmutableVariable 500 नीति में इस्तेमाल किए गए वैरिएबल में बदलाव नहीं किया जा सकता. नीति इसे सेट नहीं कर सकी वैरिएबल.
steps.extractvariables.InvalidJSONPath 500 यह गड़बड़ी तब होती है, जब किसी अमान्य JSON पाथ का इस्तेमाल JSONPath एलिमेंट में किया जाता है की नीति देखें. उदाहरण के लिए, अगर JSON पेलोड में ऑब्जेक्ट Name नहीं है, तो हालांकि, नीति में पाथ के तौर पर Name को तय करने पर यह गड़बड़ी दिखती है.
steps.extractvariables.JsonPathParsingFailure 500 यह गड़बड़ी तब होती है, जब नीति JSON पाथ को पार्स नहीं कर पाती और Source एलिमेंट में दिए गए फ़्लो वैरिएबल से डेटा निकालें. आम तौर पर यह ऐसा तब होता है, जब Source एलिमेंट में दिया गया फ़्लो वैरिएबल मौजूदा कॉलम में मौजूद न हो फ़्लो.
steps.extractvariables.SetVariableFailed 500 यह गड़बड़ी तब होती है, जब नीति वैल्यू को वैरिएबल पर सेट नहीं कर पाती. आम तौर पर गड़बड़ी तब होती है, जब ऐसे कई वैरिएबल को वैल्यू असाइन करने की कोशिश की जाती है जिनके नाम से शुरू होते हैं जिसमें समान शब्द नेस्ट किए गए डॉट से अलग किए गए फ़ॉर्मैट में हों.
steps.extractvariables.SourceMessageNotAvailable 500 यह गड़बड़ी तब होती है, जब मैसेज नीति के Source एलिमेंट में दिया गया वैरिएबल इनमें से कोई एक हो:
  • दायरे से बाहर (उस खास फ़्लो में उपलब्ध नहीं होता जहां नीति लागू की जा रही हो) या
  • हल नहीं किया जा सकता (तय नहीं किया गया है)
steps.extractvariables.UnableToCast 500 यह गड़बड़ी तब होती है, जब नीति एक्सट्रैक्ट किए गए कॉन्टेंट को कास्ट नहीं कर पाती है मान को किसी वैरिएबल के लिए बदलें. आम तौर पर, ऐसा तब होता है, जब आप एक डेटा टाइप को दूसरे डेटा टाइप के वैरिएबल में बदल देना चाहिए.

डिप्लॉयमेंट से जुड़ी गड़बड़ियां

ये गड़बड़ियां तब हो सकती हैं, जब इस नीति वाली प्रॉक्सी को डिप्लॉय किया जाता है.

गड़बड़ी का नाम वजह ठीक करें
NothingToExtract अगर नीति में URIPath, QueryParam, में से कोई भी एलिमेंट नहीं है, तो Header, FormParam, XMLPayload या JSONPayload, एपीआई प्रॉक्सी को डिप्लॉय नहीं किया जा सकता, क्योंकि एक्सट्रैक्ट करने के लिए कुछ नहीं है.
NONEmptyPrefixMappedToEmptyURI यह गड़बड़ी तब होती है, जब नीति में कोई प्रीफ़िक्स शामिल हो XMLPayload एलिमेंट के नीचे Namespace एलिमेंट है, लेकिन कोई यूआरआई नहीं है तय किया गया है.
DuplicatePrefix यह गड़बड़ी तब होती है, जब नीति में वही प्रीफ़िक्स इससे ज़्यादा हो XMLPayload एलिमेंट के अंदर Namespace एलिमेंट में एक बार.
NoXPathsToEvaluate अगर नीति के अंदर XPath एलिमेंट नहीं है XMLPayload एलिमेंट का इस्तेमाल करने पर, इस गड़बड़ी की वजह से एपीआई प्रॉक्सी को डिप्लॉय नहीं किया जा सकता.
EmptyXPathExpression अगर नीति में XMLPayload में कोई खाली XPath एक्सप्रेशन है एलीमेंट का उपयोग नहीं कर पाते हैं तो API प्रॉक्सी का परिनियोजन नहीं हो पाता है.
NoJSONPathsToEvaluate अगर नीति के अंदर JSONPath एलिमेंट नहीं है JSONPayload एलिमेंट का इस्तेमाल करने पर, इस गड़बड़ी की वजह से एपीआई प्रॉक्सी को डिप्लॉय नहीं किया जा सकता.
EmptyJSONPathExpression अगर नीति के अंदर कोई खाली XPath एक्सप्रेशन है, तो XMLPayload एलिमेंट का इस्तेमाल करने पर, एपीआई प्रॉक्सी को डिप्लॉय नहीं किया जा सकता.
MissingName अगर नीति के किसी भी हिस्से में, name एट्रिब्यूट मौजूद नहीं है, तो एलिमेंट, जैसे कि QueryParam, Header, FormParam या Variable, जहां इसकी ज़रूरत होती है वहां एपीआई प्रॉक्सी को डिप्लॉय नहीं किया जा सकता.
PatternWithoutVariable अगर नीति के Pattern एलिमेंट में कोई वैरिएबल तय नहीं किया गया है, तो तब एपीआई प्रॉक्सी को डिप्लॉय नहीं किया जा सकता. Pattern एलिमेंट के लिए यह नाम होना ज़रूरी है वह वैरिएबल जिसमें एक्सट्रैक्ट किया गया डेटा सेव किया जाएगा.
CannotBeConvertedToNodeset अगर इस नीति में ऐसा XPath एक्सप्रेशन है जिसमें Variable टाइप nodeset के तौर पर तय किया जाता है, लेकिन एक्सप्रेशन को नोडसेट में नहीं बदला जा सकता. इसके बाद, एपीआई प्रॉक्सी को डिप्लॉय नहीं किया जा सकता.
JSONPathCompilationFailed यह नीति, दिए गए JSON पाथ को कंपाइल नहीं कर सकी.
InstantiationFailed नीति इंस्टैंशिएट नहीं की जा सकी.
XPathCompilationFailed अगर XPath एलिमेंट में इस्तेमाल किया गया प्रीफ़िक्स या वैल्यू, इनमें से किसी का भी हिस्सा नहीं है नीति में बताए गए नेमस्पेस, फिर एपीआई प्रॉक्सी के डिप्लॉयमेंट की विफल होता है.
InvalidPattern अगर URIPath जैसे किसी भी एलिमेंट में Pattern एलिमेंट की डेफ़िनिशन अमान्य है, तो QueryParam, Header, FormParam, और XMLPayload या JSONPayload, फिर एपीआई प्रॉक्सी काम नहीं कर रहा है.

गड़बड़ी के वैरिएबल

ये वैरिएबल तब सेट किए जाते हैं, जब यह नीति रनटाइम के दौरान कोई गड़बड़ी ट्रिगर करती है. ज़्यादा जानकारी के लिए, देखें आपको क्या नीति से जुड़ी गड़बड़ियों के बारे में जानकारी होनी चाहिए.

वैरिएबल कहां उदाहरण
fault.name="fault_name" fault_name गड़बड़ी का नाम है, जैसा कि ऊपर रनटाइम में गड़बड़ियां टेबल में बताया गया है. गड़बड़ी का नाम, गड़बड़ी के कोड का आखिरी हिस्सा होता है. fault.name = "SourceMessageNotAvailable"
extractvariables.policy_name.failed policy_name, उपयोगकर्ता की ओर से बताया गया उस नीति का नाम है जिसमें गड़बड़ी हुई है. extractvariables.EV-ParseJsonResponse.failed = true

गड़बड़ी के रिस्पॉन्स का उदाहरण

{
   "fault":{
      "detail":{
         "errorcode":"steps.extractvariables.SourceMessageNotAvailable"
      },
      "faultstring":"request message is not available for ExtractVariable: EV-ParseJsonResponse"
   }
}

गड़बड़ी के नियम का उदाहरण

<FaultRule name="Extract Variable Faults">
    <Step>
        <Name>AM-CustomErrorMessage</Name>
        <Condition>(fault.name = "SourceMessageNotAvailable") </Condition>
    </Step>
    <Condition>(extractvariables.EM-ParseJsonResponse.failed = true) </Condition>
</FaultRule>

स्कीमा

मिलते-जुलते विषय

विश्लेषण API मैसेज में, अपने हिसाब से आंकड़े शेयर करने की सुविधा का इस्तेमाल करना

वैरिएबल रेफ़रंस