এক্সট্রাক্ট ভেরিয়েবল নীতি

আপনি Apigee Edge ডকুমেন্টেশন দেখছেন।
Apigee X ডকুমেন্টেশনে যান
তথ্য

কি

ExtractVariables নীতি একটি অনুরোধ বা প্রতিক্রিয়া থেকে বিষয়বস্তু বের করে এবং সেই বিষয়বস্তুর জন্য একটি ভেরিয়েবলের মান সেট করে। আপনি শিরোনাম, URI পাথ, JSON/XML পেলোড, ফর্ম প্যারামিটার এবং ক্যোয়ারী প্যারামিটার সহ বার্তার যেকোনো অংশ বের করতে পারেন। নীতিটি বার্তা সামগ্রীতে একটি পাঠ্য প্যাটার্ন প্রয়োগ করে কাজ করে এবং একটি মিল খুঁজে পাওয়ার পরে, নির্দিষ্ট বার্তা সামগ্রীর সাথে একটি পরিবর্তনশীল সেট করে৷

আপনি প্রায়ই অনুরোধ বা প্রতিক্রিয়া বার্তা থেকে তথ্য বের করতে এই নীতিটি ব্যবহার করলে, আপনি AccessEntity নীতি , XML অবজেক্ট বা JSON অবজেক্ট দ্বারা তৈরি সত্তা সহ অন্যান্য উত্স থেকে তথ্য বের করতেও এটি ব্যবহার করতে পারেন৷

নির্দিষ্ট বার্তা বিষয়বস্তু নিষ্কাশন করার পরে, আপনি একটি অনুরোধ এবং প্রতিক্রিয়া প্রক্রিয়াকরণের অংশ হিসাবে অন্যান্য নীতিতে পরিবর্তনশীল উল্লেখ করতে পারেন।

ভিডিও

ExtractVariables নীতি সম্পর্কে আরও জানতে নিম্নলিখিত ভিডিওগুলি দেখুন৷

ভিডিও বর্ণনা
এক্সএমএল পেলোড থেকে ভেরিয়েবল বের করুন এক্সট্রাক্ট ভেরিয়েবল নীতি ব্যবহার করে একটি XML পেলোড থেকে ভেরিয়েবল বের করুন।
JSON পেলোড থেকে ভেরিয়েবল বের করুন এক্সট্র্যাক্ট ভেরিয়েবল নীতি ব্যবহার করে একটি JSON পেলোড থেকে ভেরিয়েবল বের করুন।
প্যারামিটার থেকে ভেরিয়েবল বের করুন প্যারামিটার থেকে ভেরিয়েবল বের করুন, যেমন ক্যোয়ারী, হেডার, ফর্ম বা URI প্যারামিটার।
মাল্টি-ভ্যালু প্যারামিটার থেকে ভেরিয়েবল বের করুন মাল্টি-ভ্যালু প্যারামিটার থেকে ভেরিয়েবল বের করুন।
ক্যোয়ারী প্যারামিটার থেকে ভেরিয়েবল বের করুন (ক্লাসিক এজ) ক্লাসিক এজ UI ব্যবহার করে একটি ক্যোয়ারী প্যারামিটার থেকে ভেরিয়েবল বের করুন।
XML বা JSON পেলোড (ক্লাসিক এজ) থেকে ভেরিয়েবল বের করুন ক্লাসিক এজ UI ব্যবহার করে একটি XML বা JSON পেলোড থেকে ভেরিয়েবল বের করুন।

নমুনা

এই নীতি কোডের নমুনাগুলি কীভাবে নিম্নলিখিত ধরনের শিল্পকর্ম থেকে ভেরিয়েবল বের করতে হয় তা ব্যাখ্যা করে:

গিটহাব

এই লিঙ্কগুলি কর্মরত API প্রক্সি নমুনাগুলির দিকে নির্দেশ করে যা আপনি এজ এ স্থাপন এবং চালাতে পারেন। তারা ExtractVariables ব্যবহার করে এবং GitHub-এ Apigee-এর api-প্ল্যাটফর্ম-নমুনা সংগ্রহস্থলে অবস্থিত। 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> উপাদানটি URI পাথ থেকে তথ্য বের করতে ExtractVariables নীতিকে বলে। <Pattern> উপাদানটি URI পাথে প্রয়োগ করার জন্য প্যাটার্ন নির্দিষ্ট করে। প্যাটার্নটিকে একটি সাধারণ টেমপ্লেট হিসাবে বিবেচনা করা হয়, কোঁকড়া বন্ধনীগুলি URI পাথের বিভিন্ন অংশকে নির্দেশ করে।

সেট করা ভেরিয়েবলের নাম <VariablePrefix> উপাদানে উল্লিখিত মান দ্বারা নির্ধারিত হয়, সেইসাথে <Pattern> উপাদানের মধ্যে কোঁকড়া বন্ধনী {} দ্বারা আবদ্ধ মান। দুটি মান একটি ইন্টারভেনিং ডট দ্বারা যুক্ত হয়, যার ফলে উদাহরণ স্বরূপ urirequest.id এর একটি পরিবর্তনশীল নাম। যদি কোন <VariablePrefix> উপাদান না থাকে, তাহলে ভেরিয়েবলের নামটি শুধুমাত্র কোঁকড়া বন্ধনীতে আবদ্ধ মান।

নিম্নলিখিত আগত অনুরোধের সাথে কাজ করার জন্য উপরের নমুনা নীতি কোডটি বিবেচনা করুন:

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

ধরুন API প্রক্সির বেসপাথ হল /svc1 । যখন Apigee Edge এই আগত অনুরোধে উপরের ExtractVariables নীতি কোড প্রয়োগ করে, তখন এটি urirequest.id পরিবর্তনশীলকে 12797282 এ সেট করে। Apigee Edge নীতিটি কার্যকর করার পরে, প্রসেসিং ফ্লোতে পরবর্তী নীতি বা কোড 12797282 স্ট্রিং মান পেতে urirequest.id নামের ভেরিয়েবলটিকে উল্লেখ করতে পারে।

উদাহরণস্বরূপ, নিম্নলিখিত AssignMessage নীতিটি একটি নতুন অনুরোধ বার্তার পেলোডে সেই ভেরিয়েবলের মান এম্বেড করে:

<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 অ্যাক্সেস করতে পারেন। উদাহরণস্বরূপ, নিম্নলিখিত AssignMessage নীতি অনুরোধের পেলোডে অনুলিপি করে:

<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>

ধরুন আপনার API ডিজাইন আপনাকে একই নামের একাধিক ক্যোয়ারী প্যারামিটার নির্দিষ্ট করতে দেয়। আপনি ক্যোয়ারী প্যারামিটার "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>

ধরুন আপনার API OAuth v2.0 বহনকারী টোকেন ব্যবহার করে। একটি OAuth v2.0 টোকেন সহ একটি অনুরোধের সাথে কাজ করার জন্য উপরের নমুনা নীতি কোডটি বিবেচনা করুন যাতে এই ধরনের একটি শিরোনাম রয়েছে: Authorization: Bearer TU08xptfFfeM7aS0xHqlxTgEAdAM.

API ডিজাইনার হিসাবে, ধরুন আপনি ক্যাশে লুকআপে একটি কী হিসাবে টোকেন মান (কিন্তু পুরো হেডার নয়) ব্যবহার করতে চান। আপনি টোকেন বের করতে উপরে 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 অ্যাক্সেস করতে পারেন। উদাহরণ স্বরূপ, নিম্নোক্ত AssignMessage নীতি এটিকে প্রতিক্রিয়ায় "অক্ষাংশ" নামের একটি শিরোনামে অনুলিপি করে:

<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>

এক্সএমএল

<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>

নিম্নলিখিত XML প্রতিক্রিয়া পেলোড বিবেচনা করুন:

<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 এই XML বার্তার উপরে ExtractVariables নীতি কোড প্রয়োগ করে, তখন এটি তিনটি ভেরিয়েবল সেট করে: directionsresponse.travelmode, directionsresponse.duration এবং directionsresponse.timeunit । সমস্ত ভেরিয়েবল directionsresponse একই পরিবর্তনশীল উপসর্গ ব্যবহার করে। এই ভেরিয়েবলের প্রত্যয়টি <Variable> উপাদানের name বৈশিষ্ট্য দ্বারা স্পষ্টভাবে নির্দিষ্ট করা হয়েছে।

পরিবর্তনশীল directionsresponse.travelmode DRIVING মান পায়। পরিবর্তনশীল directionsresponse.duration মান 19 পায়। পরিবর্তনশীল directionsresponse.timeunit মান minutes পায়।

আপনি এখন আপনার প্রক্সিতে পরিবর্তনশীল directionresponse.travelmode অ্যাক্সেস করতে পারেন। উদাহরণস্বরূপ, নিম্নলিখিত AssignMessage নীতিটি প্রতিক্রিয়াতে "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 নীতি সম্পর্কে

API বিকাশকারীরা API প্রক্সি তৈরি করে যা হেডার, URI পাথ, পেলোড এবং ক্যোয়ারী প্যারামিটার সহ বার্তাগুলির বিষয়বস্তুর উপর ভিত্তি করে ভিন্নভাবে আচরণ করে। প্রায়শই, কন্ডিশন স্টেটমেন্টে ব্যবহারের জন্য প্রক্সি এই কন্টেন্টের কিছু অংশ বের করে। এটি করার জন্য ExtractVariables নীতি ব্যবহার করুন।

ExtractVariables নীতি সংজ্ঞায়িত করার সময়, আপনি চয়ন করতে পারেন:

  • ভেরিয়েবলের নাম সেট করতে হবে
  • ভেরিয়েবলের উৎস
  • কয়টি ভেরিয়েবল এক্সট্রাক্ট এবং সেট করতে হবে

সম্পাদিত হলে, নীতিটি সামগ্রীতে একটি পাঠ্য প্যাটার্ন প্রয়োগ করে এবং একটি মিল খুঁজে পাওয়ার পরে, বিষয়বস্তুর সাথে মনোনীত পরিবর্তনশীলের মান সেট করে। অন্যান্য নীতি এবং কোড তখন গতিশীল আচরণ সক্ষম করতে বা এজ এপিআই অ্যানালিটিক্সে ব্যবসার ডেটা পাঠাতে সেই ভেরিয়েবলগুলিকে গ্রাস করতে পারে।

বিষয়বস্তু-চালিত বিশ্লেষণ প্রতিবেদন তৈরি করতে ExtractVariables কিভাবে ব্যবহার করা যেতে পারে তা দেখতে, কাস্টম বিশ্লেষণ ব্যবহার করে API বার্তা সামগ্রী বিশ্লেষণ দেখুন।

ব্যাপ্তি

ExtractVariables নীতির সাথে সেট করা ভেরিয়েবলের বিশ্বব্যাপী সুযোগ রয়েছে। অর্থাৎ, ExtractVariables নীতি একটি নতুন ভেরিয়েবল সংজ্ঞায়িত করার পরে, আপনি প্রবাহের যেকোন পর্যায়ে (যা ExtractVariables নীতির পরে কার্যকর হয়) যেকোনো নীতি বা কোড থেকে সেই ভেরিয়েবলটি অ্যাক্সেস করতে পারবেন। এর মধ্যে রয়েছে:

  • PreFlow: ProxyEndpoint এবং TargetEndpoint (অনুরোধ এবং প্রতিক্রিয়া)
  • পোস্টফ্লো: প্রক্সিএন্ডপয়েন্ট এবং টার্গেটএন্ডপয়েন্ট (অনুরোধ এবং প্রতিক্রিয়া)
  • PostClientFlow: ProxyEndpoint (শুধুমাত্র প্রতিক্রিয়া, বার্তা লগিং নীতি ব্যবহার করে)
  • ত্রুটি প্রবাহ

মিল এবং পরিবর্তনশীল সৃষ্টি সম্পর্কে

ExtractVariables নীতি একটি অনুরোধ বা প্রতিক্রিয়া থেকে তথ্য বের করে এবং একটি ভেরিয়েবলের কাছে সেই তথ্য লিখে। URI পাথ বা XML ডেটার মতো প্রতিটি ধরনের তথ্য যা আপনি বের করতে পারেন, তার জন্য আপনি মিলের প্যাটার্ন এবং এক্সট্র্যাক্ট করা তথ্য ধরে রাখতে ব্যবহৃত ভেরিয়েবলের নাম উল্লেখ করেন।

যাইহোক, প্যাটার্ন ম্যাচিং পদ্ধতিটি নিষ্কাশনের উত্সের উপর নির্ভর করে। নিম্নলিখিত বিভাগগুলি আপনি আহরণ করতে পারেন এমন দুটি মৌলিক বিভাগের তথ্য বর্ণনা করে।

ইউআরআই পাথ, ক্যোয়ারী প্যারামিটার, হেডার, ফর্ম প্যারামিটার এবং ভেরিয়েবলের সাথে মিলে যাওয়া

একটি URI পাথ, ক্যোয়ারী প্যারামিটার, হেডার, ফর্ম প্যারামিটার এবং ভেরিয়েবল থেকে তথ্য বের করার সময় আপনি মিলের জন্য এক বা একাধিক প্যাটার্ন নির্দিষ্ট করতে <প্যাটার্ন> ট্যাগ ব্যবহার করেন। উদাহরণস্বরূপ, নিম্নলিখিত নীতি উদাহরণ URI পাথের জন্য একটি একক মিলে যাওয়া প্যাটার্ন দেখায়:

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

এই উদাহরণে, urirequest.pathSeg ভেরিয়েবলটি "/a/" এর পরে proxy.pathsuffix-এ যা দেখায় তাতে সেট করা হয়েছে। উদাহরণস্বরূপ, ধরুন আপনার API প্রক্সির বেস পাথ হল /basepath/v1http://myCo.com/basepath/v1/a/b এ একটি অন্তর্মুখী অনুরোধের সাথে ভেরিয়েবলটি "b" এ সেট করা হয়েছে।

একাধিক নিদর্শন নির্দিষ্ট করা

আপনি <প্যাটার্ন> ট্যাগের সাথে মিলে যাওয়ার জন্য একাধিক প্যাটার নির্দিষ্ট করতে পারেন, যেখানে:

  • সমস্ত নিদর্শন ম্যাচের জন্য পরীক্ষা করা হয়.
  • যদি প্যাটার্নগুলির কোনোটি মেলে না, তাহলে নীতি কিছুই করে না এবং পরিবর্তনশীল(গুলি) তৈরি করা হয় না।
  • যদি একাধিক প্যাটার্ন মিলে যায়, দীর্ঘতম পাথের অংশগুলির সাথে প্যাটার্নটি নিষ্কাশনের জন্য ব্যবহার করা হয়।
  • যদি দুটি মিলে যাওয়া প্যাটার্নে একই দীর্ঘতম পাথ সেগমেন্ট থাকে, তাহলে নীতিতে প্রথমে নির্দিষ্ট করা প্যাটার্নটি নিষ্কাশনের জন্য ব্যবহার করা হয়।

পরবর্তী উদাহরণে, আপনি একটি নীতি তৈরি করেন যাতে URI পাথের জন্য তিনটি মিলে যাওয়া প্যাটার্ন রয়েছে:

<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 এর একটি বেসপাথ সহ একটি API প্রক্সির জন্য, API প্রক্সিতে অন্তর্মুখী অনুরোধ URLটি এই ফর্মের:

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

এই উদাহরণে, প্রথম প্যাটার্নটি URI-এর সাথে মেলে এবং urirequest.pathSeg ভেরিয়েবলটি "b" এ সেট করা হয়েছে।

অনুরোধ URL হলে:

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>

ইনবাউন্ড অনুরোধ URL-এর জন্য /basepath/v1 এর একটি বেস পাথ সহ একটি API প্রক্সিকে আবার ধরুন:

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 ভেরিয়েবলটি খালি। অনুরোধে একই নামের একাধিক আইটেম থাকলে যেকোনও সময় ইন্ডেক্সিং ব্যবহার করুন।

প্যাটার্নে বিশেষ অক্ষর ব্যবহার করা

ইউআরআই পাথ মেলে, আপনি প্যাটার্নে "*" এবং "**" ওয়াইল্ডকার্ড অক্ষর ব্যবহার করতে পারেন, যেখানে:

  • "*" পথের যেকোনো একটি অংশের সাথে মেলে
  • "**" পাথের একাধিক অংশের সাথে মেলে

উদাহরণ স্বরূপ, আপনি <URIPath> এলিমেন্টের প্যাটার্ন নির্দিষ্ট করুন যেমন নিচে দেখানো হয়েছে:

<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"।

ক্যোয়ারী প্যারামিটার, হেডার এবং ফর্ম প্যারামিটারে প্যাটার্ন নির্দিষ্ট করার সময়, "*" অক্ষরটি যেকোন সংখ্যক অক্ষর মেলে তা নির্দিষ্ট করে। উদাহরণস্বরূপ, একটি শিরোনাম মেলে যখন, প্যাটার্নটি নির্দিষ্ট করুন:

*;চরসেট={এনকোডিং}

এই প্যাটার্নটি "text/xml;charset=UTF-16" এবং "application/xml;charset=ASCII" মানগুলির সাথে মেলে।

ExtractVariables পলিসিতে পাস করা মানটিতে একটি বিশেষ অক্ষর থাকে, যেমন "{", এটিকে এড়িয়ে যেতে "%" অক্ষর ব্যবহার করুন। নিম্নলিখিত উদাহরণটি প্যাটার্নের "{" এবং "}" অক্ষরগুলিকে এড়িয়ে যায় কারণ সেগুলি ক্যোয়ারী প্যারামিটারের মানতে আক্ষরিক অক্ষর হিসাবে ব্যবহৃত হয়:

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

এই উদাহরণে, প্যাটার্নটি "{user} Steve" মানের সাথে মেলে কিন্তু "user Steve" মানের সাথে নয়।

মিল JSON এবং XML

JSON এবং XML থেকে ডেটা বের করার সময়, আপনি নীতিতে এক বা একাধিক <variable> ট্যাগ উল্লেখ করেন। <ভেরিয়েবল> ট্যাগটি গন্তব্য ভেরিয়েবলের নাম উল্লেখ করে যেখানে নিষ্কাশিত তথ্য সংরক্ষণ করা হয় এবং নিষ্কাশিত তথ্যের জন্য JsonPath (JSON) বা XPATH (XML)।

নীতির সমস্ত <Variable> ট্যাগ মূল্যায়ন করা হয়, যাতে আপনি একটি একক নীতি থেকে একাধিক ভেরিয়েবল তৈরি করতে পারেন। যদি <Variable> ট্যাগ 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>

<ExtractVariables> বৈশিষ্ট্য

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

নিম্নলিখিত সারণী সমস্ত নীতির মূল উপাদানগুলির জন্য সাধারণ বৈশিষ্ট্যগুলি বর্ণনা করে:

বৈশিষ্ট্য বর্ণনা ডিফল্ট উপস্থিতি
name

নীতির অভ্যন্তরীণ নাম। name বৈশিষ্ট্যের মানটিতে অক্ষর, সংখ্যা, স্পেস, হাইফেন, আন্ডারস্কোর এবং পিরিয়ড থাকতে পারে। এই মান 255 অক্ষরের বেশি হতে পারে না।

ঐচ্ছিকভাবে, ম্যানেজমেন্ট UI প্রক্সি এডিটরে নীতিটিকে একটি ভিন্ন, প্রাকৃতিক-ভাষা নামের সাথে লেবেল করতে <DisplayName> উপাদানটি ব্যবহার করুন।

N/A প্রয়োজন
continueOnError

একটি নীতি ব্যর্থ হলে একটি ত্রুটি ফেরত দিতে false সেট করুন৷ এটি বেশিরভাগ নীতির জন্য প্রত্যাশিত আচরণ।

একটি নীতি ব্যর্থ হওয়ার পরেও ফ্লো এক্সিকিউশন চালিয়ে যেতে true সেট করুন৷

মিথ্যা ঐচ্ছিক
enabled

নীতি প্রয়োগ করতে true সেট করুন৷

নীতি বন্ধ করতে false সেট করুন। নীতিটি প্রবাহের সাথে সংযুক্ত থাকলেও তা কার্যকর করা হবে না।

সত্য ঐচ্ছিক
async

এই বৈশিষ্ট্যটি অবমূল্যায়ন করা হয়েছে৷

মিথ্যা অবচয়

<DisplayName> উপাদান

ম্যানেজমেন্ট UI প্রক্সি এডিটরে নীতিটিকে একটি ভিন্ন, প্রাকৃতিক-ভাষা নামের সাথে লেবেল করতে name বৈশিষ্ট্য ছাড়াও ব্যবহার করুন।

<DisplayName>Policy Display Name</DisplayName>
ডিফল্ট

N/A

আপনি এই উপাদানটি বাদ দিলে, নীতির name বৈশিষ্ট্যের মান ব্যবহার করা হবে।

উপস্থিতি ঐচ্ছিক
টাইপ স্ট্রিং

<উৎস> উপাদান

(ঐচ্ছিক) পার্স করার জন্য ভেরিয়েবল নির্দিষ্ট করে। <Source> message মান ডিফল্ট। message মান প্রসঙ্গ-সংবেদনশীল। একটি অনুরোধ প্রবাহে, message অনুরোধ বার্তার সমাধান করে। একটি প্রতিক্রিয়া প্রবাহে, message প্রতিক্রিয়া বার্তার সমাধান করে।

যখন আপনি প্রায়ই একটি অনুরোধ বা প্রতিক্রিয়া বার্তা থেকে তথ্য আহরণ করতে এই নীতিটি ব্যবহার করেন, আপনি যেকোনো পরিবর্তনশীল থেকে তথ্য বের করতে এটি ব্যবহার করতে পারেন। উদাহরণ স্বরূপ, আপনি এটি ব্যবহার করতে পারেন AccessEntity নীতি দ্বারা তৈরি একটি সত্তা থেকে, পরিষেবা কলআউট নীতি দ্বারা প্রত্যাবর্তিত ডেটা থেকে, অথবা একটি XML বা JSON অবজেক্ট থেকে তথ্য বের করতে৷

যদি <Source> সমাধান করা না যায়, বা একটি নন-মেসেজ টাইপের সমাধান করা যায়, নীতিটি প্রতিক্রিয়া জানাতে ব্যর্থ হবে।

<Source clearPayload="true|false">request</Source>
ডিফল্ট: বার্তা
উপস্থিতি: ঐচ্ছিক
প্রকার: স্ট্রিং

গুণাবলী

বৈশিষ্ট্য বর্ণনা ডিফল্ট উপস্থিতি টাইপ
ক্লিয়ারপেলোড

আপনি যদি <উৎস> থেকে ডেটা বের করার পরে উল্লেখিত পেলোড সাফ করতে চান তাহলে সত্যে সেট করুন।

এক্সট্র্যাক্ট ভেরিয়েবল চালানোর পরে উৎস বার্তার প্রয়োজন না হলেই <clearPayload> বিকল্পটি ব্যবহার করুন। সত্যে সেট করা বার্তা দ্বারা ব্যবহৃত মেমরি মুক্ত করে।

মিথ্যা

ঐচ্ছিক বুলিয়ান

<VariablePrefix> উপাদান

(ঐচ্ছিক) সম্পূর্ণ পরিবর্তনশীল নামটি <VariablePrefix> , একটি বিন্দু এবং যে নামটি আপনি <Pattern> উপাদান বা <variable> এলিমেন্টে {কোঁকড়া ধনুর্বন্ধনীতে সংজ্ঞায়িত করেছেন তা যোগ করে তৈরি করা হয়। যেমন: myprefix.id , myprefix.dbncode বা myprefix.oauthtoken.

<VariablePrefix>myprefix</VariablePrefix>

উদাহরণস্বরূপ, ধরুন নামের মান হল "ব্যবহারকারী"।

  • যদি <VariablePrefix> নির্দিষ্ট করা না থাকে, তাহলে নিষ্কাশিত মানগুলি একটি ভেরিয়েবল নামের user বরাদ্দ করা হয়।
  • যদি <VariablePrefix> myprefix হিসাবে নির্দিষ্ট করা হয়, তাহলে নিষ্কাশিত মানগুলি myprefix.user নামের একটি ভেরিয়েবলে বরাদ্দ করা হয়।
ডিফল্ট: N/A
উপস্থিতি: ঐচ্ছিক
প্রকার: স্ট্রিং

<অমীমাংসিত ভেরিয়েবল> এলিমেন্টকে উপেক্ষা করুন

(ঐচ্ছিক) কোনো অমীমাংসিত ভেরিয়েবলকে খালি স্ট্রিং (নাল) হিসাবে বিবেচনা করার জন্য true সেট করুন। যেকোন রেফারেন্স ভেরিয়েবল অমীমাংসিত হলে আপনি যদি নীতিটি একটি ত্রুটি ছুঁড়তে চান তবে false সেট করুন৷

<IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
ডিফল্ট: মিথ্যা
উপস্থিতি: ঐচ্ছিক
প্রকার: বুলিয়ান

যদি একটি XPath রেফারেন্স একটি <XMLPayload> এ অমীমাংসিত হয়, তাহলে নীতিটি নিম্নলিখিত ত্রুটিটি নিক্ষেপ করে:

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

<URIPath> উপাদান

(ঐচ্ছিক, তবে আরও তথ্যের জন্য নীচের টেবিলে উপস্থিতি সারিটি দেখুন।) একটি অনুরোধ উত্স বার্তার proxy.pathsuffix থেকে একটি মান বের করে। প্যাটার্নে প্রয়োগ করা পাথ হল proxy.pathsuffix, যা API প্রক্সির জন্য বেসপাথ অন্তর্ভুক্ত করে না। যদি উৎস বার্তাটি একটি বার্তা প্রকারের প্রতিক্রিয়ার সমাধান করে, তাহলে এই উপাদানটি কিছুই করে না।

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

একাধিক <প্যাটার্ন> উপাদান ব্যবহার করা সম্ভব:

<URIPath>
   <Pattern ignoreCase="false">/accounts/{id}</Pattern>
   <Pattern ignoreCase="false">/accounts/{id}/transactions/{index}</Pattern>
</URIPath>
ডিফল্ট: N/A
উপস্থিতি: ঐচ্ছিক। যাইহোক, আপনাকে অবশ্যই নিম্নলিখিতগুলির মধ্যে অন্তত একটি অন্তর্ভুক্ত করতে হবে: <URIPath> , <QueryParam> , <Header> , <FormParam> , <JSONPayload> , বা <XMLPayload>.
প্রকার: N/A

গুণাবলী

বৈশিষ্ট্য বর্ণনা ডিফল্ট উপস্থিতি টাইপ
ignoreCase প্যাটার্নের সাথে মিলে যাওয়ার সময় কেস উপেক্ষা করার জন্য নির্দিষ্ট করে।

মিথ্যা

ঐচ্ছিক বুলিয়ান

<QueryParam> উপাদান

(ঐচ্ছিক, কিন্তু আরও তথ্যের জন্য নীচের টেবিলে উপস্থিতি সারিটি দেখুন।) একটি অনুরোধ উত্স বার্তার নির্দিষ্ট ক্যোয়ারী প্যারামিটার থেকে একটি মান বের করে। যদি উৎস বার্তাটি একটি বার্তা প্রকারের প্রতিক্রিয়ার সমাধান করে, তাহলে এই উপাদানটি কিছুই করে না।

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

একাধিক ক্যোয়ারী প্যারামিটারের একই নাম থাকলে, পরামিতিগুলি উল্লেখ করতে সূচী ব্যবহার করুন:

<QueryParam name="w.2">
   <Pattern ignoreCase="true">{secondW}</Pattern>
</QueryParam>
ডিফল্ট: N/A
উপস্থিতি: ঐচ্ছিক। যাইহোক, আপনাকে অবশ্যই নিম্নলিখিতগুলির মধ্যে অন্তত একটি অন্তর্ভুক্ত করতে হবে: <URIPath> , <QueryParam> , <Header> , <FormParam> , <JSONPayload> , বা <XMLPayload>.
প্রকার: N/A

গুণাবলী

বৈশিষ্ট্য বর্ণনা ডিফল্ট উপস্থিতি টাইপ
নাম ক্যোয়ারী প্যারামিটারের নাম উল্লেখ করে। যদি একাধিক ক্যোয়ারী প্যারামিটারের একই নাম থাকে, তাহলে ইন্ডেক্সড রেফারেন্সিং ব্যবহার করুন, যেখানে ক্যোয়ারী প্যারামিটারের প্রথম দৃষ্টান্তের কোনো সূচক নেই, দ্বিতীয়টি সূচী 2 এ, তৃতীয়টি সূচক 3 এ, ইত্যাদি।

N/A

প্রয়োজন স্ট্রিং

<হেডার> উপাদান

(ঐচ্ছিক, তবে আরও তথ্যের জন্য নীচের টেবিলে উপস্থিতি সারিটি দেখুন।) নির্দিষ্ট অনুরোধ বা প্রতিক্রিয়া বার্তার নির্দিষ্ট HTTP শিরোনাম থেকে একটি মান বের করে। একাধিক শিরোনাম একই নাম থাকলে, তাদের মান একটি অ্যারেতে সংরক্ষণ করা হয়।

<!-- 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>
ডিফল্ট: N/A
উপস্থিতি: ঐচ্ছিক। যাইহোক, আপনাকে অবশ্যই নিম্নলিখিতগুলির মধ্যে অন্তত একটি অন্তর্ভুক্ত করতে হবে: <URIPath> , <QueryParam> , <Header> , <FormParam> , <JSONPayload> , বা <XMLPayload>.
প্রকার: N/A

গুণাবলী

বৈশিষ্ট্য বর্ণনা ডিফল্ট উপস্থিতি টাইপ
নাম হেডারের নাম উল্লেখ করে যেখান থেকে আপনি মান বের করেন। যদি একাধিক হেডারের একই নাম থাকে, তাহলে ইনডেক্সড রেফারেন্সিং ব্যবহার করুন, যেখানে হেডারের প্রথম দৃষ্টান্তের কোনো সূচক নেই, দ্বিতীয়টি সূচী 2-এ, তৃতীয়টি 3-এ, ইত্যাদি। অ্যারেতে সমস্ত হেডার পেতে .values ​​ব্যবহার করুন।

N/A

প্রয়োজন স্ট্রিং

<FormParam> উপাদান

(ঐচ্ছিক, কিন্তু আরও তথ্যের জন্য নীচের টেবিলে উপস্থিতি সারি দেখুন।) নির্দিষ্ট অনুরোধ বা প্রতিক্রিয়া বার্তার নির্দিষ্ট ফর্ম প্যারামিটার থেকে একটি মান বের করে। ফর্ম প্যারামিটারগুলি শুধুমাত্র তখনই বের করা যেতে পারে যখন নির্দিষ্ট বার্তার Content-Type শিরোনামটি application/x-www-form-urlencoded হয়।

<FormParam name="greeting">
    <Pattern>hello {user}</Pattern>
</FormParam>
ডিফল্ট: N/A
উপস্থিতি: ঐচ্ছিক। যাইহোক, আপনাকে অবশ্যই নিম্নলিখিতগুলির মধ্যে অন্তত একটি অন্তর্ভুক্ত করতে হবে: <URIPath> , <QueryParam> , <Header> , <FormParam> , <JSONPayload> , বা <XMLPayload>.
প্রকার: N/A

গুণাবলী

বৈশিষ্ট্য বর্ণনা ডিফল্ট উপস্থিতি টাইপ
নাম ফর্ম প্যারামিটারের নাম যেখান থেকে আপনি মান বের করেন।

N/A

প্রয়োজন স্ট্রিং

<ভেরিয়েবল> উপাদান

(ঐচ্ছিক, কিন্তু আরও তথ্যের জন্য নীচের টেবিলে উপস্থিতি সারিটি দেখুন।) একটি ভেরিয়েবলের নাম উল্লেখ করে যেখান থেকে একটি মান বের করতে হবে।

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

ভেরিয়েবল থেকে দুটি মান বের করতে:

<Variable name="myVar">
   <Pattern>hello {firstName} {lastName}</Pattern>
</Variable>
ডিফল্ট: N/A
উপস্থিতি: ঐচ্ছিক। যাইহোক, আপনাকে অবশ্যই নিম্নলিখিতগুলির মধ্যে অন্তত একটি অন্তর্ভুক্ত করতে হবে: <URIPath> , <QueryParam> , <Header> , <FormParam> , <JSONPayload> , বা <XMLPayload>.
প্রকার: N/A

গুণাবলী

বৈশিষ্ট্য বর্ণনা ডিফল্ট উপস্থিতি টাইপ
নাম যে ভেরিয়েবল থেকে মান বের করতে হবে তার নাম।

N/A

প্রয়োজন স্ট্রিং

<JSONPayload> উপাদান

(ঐচ্ছিক, কিন্তু আরও তথ্যের জন্য নীচের সারণীতে উপস্থিতি সারিটি দেখুন।) JSON- ফরম্যাটেড বার্তাটি নির্দিষ্ট করে যেখান থেকে ভেরিয়েবলের মান বের করা হবে। JSON নিষ্কাশন শুধুমাত্র তখনই সঞ্চালিত হয় যখন বার্তার বিষয়বস্তু-প্রকার শিরোনাম অ্যাপ্লিকেশন/json হয়।

<JSONPayload>
   <Variable name="name" type="string">
      <JSONPath>{example}</JSONPath>
   </Variable>
</JSONPayload>
ডিফল্ট: N/A
উপস্থিতি: ঐচ্ছিক। যাইহোক, আপনাকে অবশ্যই নিম্নলিখিতগুলির মধ্যে অন্তত একটি অন্তর্ভুক্ত করতে হবে: <URIPath> , <QueryParam> , <Header> , <FormParam> , <JSONPayload> , বা <XMLPayload>.
প্রকার: N/A

<JSONPayload>/<ভেরিয়েবল> উপাদান

(JSONPayload উপাদানের মধ্যে প্রয়োজনীয়।) ভেরিয়েবলটি নির্দিষ্ট করে যেখানে নিষ্কাশিত মান বরাদ্দ করা হয়। আপনি একাধিক ভেরিয়েবল তৈরি করতে <JSONPayload> উপাদানে একাধিক <Variable> ট্যাগ অন্তর্ভুক্ত করতে পারেন।

<Variable name="name" type="string">
   <JSONPath>{example}</JSONPath>
</Variable>
ডিফল্ট: N/A
উপস্থিতি: JSONPayload উপাদানের মধ্যে প্রয়োজনীয়।
প্রকার: N/A

গুণাবলী

বৈশিষ্ট্য বর্ণনা ডিফল্ট উপস্থিতি টাইপ
নাম

ভেরিয়েবলের নাম উল্লেখ করে যেখানে এক্সট্র্যাক্ট করা মান বরাদ্দ করা হবে।

নাম

প্রয়োজন স্ট্রিং
টাইপ পরিবর্তনশীল মানের ডেটা টাইপ নির্দিষ্ট করে। N/A ঐচ্ছিক

স্ট্রিং থেকে নির্বাচন করুন:

  • স্ট্রিং
  • বুলিয়ান
  • পূর্ণসংখ্যা
  • দীর্ঘ
  • ভাসা
  • দ্বিগুণ
  • নোডসেট (জেএসওএন টুকরা প্রদান করে)

<JSONPayload>/<ভেরিয়েবল>/<JSONPath> উপাদান

(JSONPayload:ভেরিয়েবল এলিমেন্টের মধ্যে প্রয়োজনীয়।) JSON-ফর্ম্যাটেড বার্তা থেকে একটি মান বের করতে ব্যবহৃত JSON পাথ নির্দিষ্ট করে।

<Variable name="name">
   <JSONPath>$.rss.channel.title</JSONPath>
</Variable>
ডিফল্ট: N/A
উপস্থিতি: প্রয়োজন
প্রকার: স্ট্রিং

<XMLPayload> উপাদান

(ঐচ্ছিক, কিন্তু আরও তথ্যের জন্য নীচের সারণীতে উপস্থিতি সারিটি দেখুন।) XML- ফরম্যাটেড বার্তাটি নির্দিষ্ট করে যেখান থেকে ভেরিয়েবলের মান বের করা হবে। XML পেলোডগুলি শুধুমাত্র তখনই বের করা হয় যখন বার্তার 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>
ডিফল্ট: N/A
উপস্থিতি: ঐচ্ছিক। যাইহোক, আপনাকে অবশ্যই নিম্নলিখিতগুলির মধ্যে অন্তত একটি অন্তর্ভুক্ত করতে হবে: <URIPath> , <QueryParam> , <Header> , <FormParam> , <JSONPayload> , বা <XMLPayload>.
প্রকার: N/A

গুণাবলী

বৈশিষ্ট্য বর্ণনা ডিফল্ট উপস্থিতি টাইপ
stopPayloadProcessing

একটি ভেরিয়েবল পপুলেট হওয়ার পরে XPath মূল্যায়ন বন্ধ করতে true সেট করুন। এর মানে হল শুধুমাত্র একটি একক ভেরিয়েবল পলিসি দ্বারা পপুলেট করা হয়েছে।

মিথ্যা

ঐচ্ছিক বুলিয়ান

<XMLPayload>/<নেমস্পেস> উপাদান

(ঐচ্ছিক) XPath মূল্যায়নে ব্যবহার করার জন্য নামস্থান নির্দিষ্ট করে। আপনি যদি আপনার XPath এক্সপ্রেশনে নামস্থান ব্যবহার করেন, তাহলে আপনাকে অবশ্যই এখানে নামস্থান ঘোষণা করতে হবে, যেমনটি নিম্নলিখিত উদাহরণে দেখানো হয়েছে।

<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>

আপনি যদি আপনার XPath অভিব্যক্তিতে নামস্থান ব্যবহার না করেন, তাহলে আপনি <Namespaces> উপাদানটি বাদ দিতে বা মন্তব্য করতে পারেন, যেমনটি নিম্নলিখিত উদাহরণটি দেখায়:

<XMLPayload stopPayloadProcessing="false">
  <!-- <Namespaces/> -->
  <Variable name="legName" type="string">
    <XPath>/Directions/route/leg/name</XPath>
  </Variable>
</XMLPayload>
ডিফল্ট: N/A
উপস্থিতি: ঐচ্ছিক
প্রকার: স্ট্রিং

গুণাবলী

বৈশিষ্ট্য বর্ণনা ডিফল্ট উপস্থিতি টাইপ
prefix

নামস্থান উপসর্গ।

N/A

প্রয়োজন স্ট্রিং

<XMLPayload>/<variable> উপাদান

(ঐচ্ছিক) ভেরিয়েবল নির্দিষ্ট করে যেখানে নিষ্কাশিত মান বরাদ্দ করা হবে।

<Variable name="name" type="boolean">
   <XPath>/test/example</XPath>
</Variable>
ডিফল্ট: N/A
উপস্থিতি: ঐচ্ছিক
প্রকার: N/A

গুণাবলী

বৈশিষ্ট্য বর্ণনা ডিফল্ট উপস্থিতি টাইপ
নাম

ভেরিয়েবলের নাম উল্লেখ করে যেখানে এক্সট্র্যাক্ট করা মান বরাদ্দ করা হবে।

নাম

প্রয়োজন স্ট্রিং
টাইপ পরিবর্তনশীল মানের ডেটা টাইপ নির্দিষ্ট করে। বুলিয়ান ঐচ্ছিক

স্ট্রিং থেকে নির্বাচন করুন:

  • স্ট্রিং
  • বুলিয়ান
  • পূর্ণসংখ্যা
  • দীর্ঘ
  • ভাসা
  • দ্বিগুণ
  • নোডসেট (একটি XML খণ্ড প্রদান করে)

<XMLPayload>/<ভেরিয়েবল>/<XPath> উপাদান

(XMLPayload:ভেরিয়েবল এলিমেন্টের মধ্যে প্রয়োজনীয়।) ভেরিয়েবলের জন্য সংজ্ঞায়িত XPath নির্দিষ্ট করে। শুধুমাত্র XPath 1.0 এক্সপ্রেশন সমর্থিত।

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

একটি নামস্থান সহ উদাহরণ। আপনি যদি আপনার XPath এক্সপ্রেশনে নামস্থান ব্যবহার করেন, তাহলে আপনাকে নীতির <XMLPayload><Namespaces> বিভাগে নামস্থান ঘোষণা করতে হবে।

<Variable name="name" type="boolean">
   <XPath>/foo:test/foo:example</XPath>
</Variable>
ডিফল্ট: N/A
উপস্থিতি: প্রয়োজন
প্রকার: স্ট্রিং

ত্রুটি উল্লেখ

এই বিভাগটি ফল্ট কোড এবং ত্রুটি বার্তাগুলি বর্ণনা করে যেগুলি ফেরত দেওয়া হয় এবং ত্রুটি ভেরিয়েবলগুলি যেগুলি এজ দ্বারা সেট করা হয় যখন এই নীতিটি একটি ত্রুটি ট্রিগার করে৷ এই তথ্যটি জানা গুরুত্বপূর্ণ যে আপনি ত্রুটিগুলি পরিচালনা করার জন্য ত্রুটির নিয়ম তৈরি করছেন কিনা। আরও জানতে, নীতিগত ত্রুটি এবং হ্যান্ডলিং ফল্ট সম্পর্কে আপনার যা জানা দরকার তা দেখুন৷

রানটাইম ত্রুটি

নীতি কার্যকর করার সময় এই ত্রুটিগুলি ঘটতে পারে৷

ফল্ট কোড HTTP স্থিতি কারণ ঠিক করুন
steps.extractvariables.ExecutionFailed 500

এই ত্রুটিটি ঘটে যখন:

  • ইনপুট পেলোড (JSON, XML) খালি।
  • নীতিতে পাস করা ইনপুট (JSON, XML, ইত্যাদি) অবৈধ বা বিকৃত।
steps.extractvariables.ImmutableVariable 500 নীতিতে ব্যবহৃত একটি পরিবর্তনশীল অপরিবর্তনীয়। নীতি এই পরিবর্তনশীল সেট করতে অক্ষম ছিল.
steps.extractvariables.InvalidJSONPath 500 যদি নীতির JSONPath এলিমেন্টে একটি অবৈধ JSON পাথ ব্যবহার করা হয় তাহলে এই সমস্যাটি ঘটে। উদাহরণস্বরূপ, যদি একটি 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 এর কোনো উপাদান না থাকে, তাহলে API প্রক্সির স্থাপনা ব্যর্থ হয়, কারণ বের করার মতো কিছুই নেই।
NONEmptyPrefixMappedToEmptyURI XMLPayload এলিমেন্টের অধীনে Namespace এলিমেন্টে যদি নীতির একটি প্রিফিক্স সংজ্ঞায়িত করা থাকে, কিন্তু কোনো URI সংজ্ঞায়িত করা না থাকে তাহলে এই সমস্যাটি ঘটে।
DuplicatePrefix XMLPayload এলিমেন্টের অধীনে Namespace এলিমেন্টে নীতির একই প্রিফিক্স একাধিকবার সংজ্ঞায়িত থাকলে এই ত্রুটি ঘটে।
NoXPathsToEvaluate যদি নীতিতে XMLPayload উপাদানের মধ্যে XPath উপাদান না থাকে, তাহলে এই ত্রুটির সাথে API প্রক্সির স্থাপনা ব্যর্থ হয়৷
EmptyXPathExpression XMLPayload উপাদানের মধ্যে যদি নীতির একটি খালি XPath এক্সপ্রেশন থাকে, তাহলে API প্রক্সির স্থাপনা ব্যর্থ হয়৷
NoJSONPathsToEvaluate যদি নীতিতে JSONPayload উপাদানের মধ্যে JSONPath উপাদান না থাকে, তাহলে এই ত্রুটির সাথে API প্রক্সির স্থাপনা ব্যর্থ হয়।
EmptyJSONPathExpression XMLPayload উপাদানের মধ্যে যদি নীতির একটি খালি XPath এক্সপ্রেশন থাকে, তাহলে API প্রক্সির স্থাপনা ব্যর্থ হয়৷
MissingName যদি নীতির QueryParam , Header , FormParam বা Variable মতো নীতি উপাদানগুলির মধ্যে কোনো name বৈশিষ্ট্য না থাকে, যেখানে এটির প্রয়োজন হয়, তাহলে API প্রক্সির স্থাপনা ব্যর্থ হয়৷
PatternWithoutVariable যদি নীতিতে Pattern উপাদানের মধ্যে নির্দিষ্ট কোনো পরিবর্তনশীল না থাকে, তাহলে API প্রক্সির স্থাপনা ব্যর্থ হয়। Pattern উপাদানটির জন্য ভেরিয়েবলের নাম প্রয়োজন যেখানে নিষ্কাশিত ডেটা সংরক্ষণ করা হবে।
CannotBeConvertedToNodeset যদি নীতিতে একটি XPath এক্সপ্রেশন থাকে যেখানে Variable টাইপটিকে নোডসেট হিসাবে সংজ্ঞায়িত করা হয়, কিন্তু অভিব্যক্তিটিকে নোডসেটে রূপান্তর করা যায় না, তাহলে API প্রক্সির স্থাপনা ব্যর্থ হয়৷
JSONPathCompilationFailed নীতিটি একটি নির্দিষ্ট JSON পাথ কম্পাইল করতে পারেনি৷
InstantiationFailed নীতি তাত্ক্ষণিক করা যায়নি.
XPathCompilationFailed যদি উপসর্গ বা XPath উপাদানে ব্যবহৃত মান নীতিতে ঘোষিত কোনো নামস্থানের অংশ না হয়, তাহলে API প্রক্সির স্থাপনা ব্যর্থ হয়।
InvalidPattern যদি নীতির মধ্যে URIPath , QueryParam , Header , FormParam , XMLPayload বা JSONPayload এর মতো উপাদানগুলির মধ্যে Pattern উপাদানের সংজ্ঞাটি অবৈধ হয়, তাহলে API প্রক্সির স্থাপনা ব্যর্থ হয়৷

ফল্ট ভেরিয়েবল

যখন এই নীতি রানটাইমে একটি ত্রুটি ট্রিগার করে তখন এই ভেরিয়েবলগুলি সেট করা হয়৷ আরও তথ্যের জন্য, নীতি ত্রুটি সম্পর্কে আপনার যা জানা দরকার তা দেখুন।

ভেরিয়েবল যেখানে উদাহরণ
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 বার্তা সামগ্রী বিশ্লেষণ করুন

ভেরিয়েবল রেফারেন্স