Apigee Edge belgelerini görüntülüyorsunuz.
.
Git:
Apigee X belgeleri. bilgi
NothingToExtract
Hata mesajı
API proxy'sinin Edge Kullanıcı Arayüzü veya Edge management API üzerinden dağıtılması şu hata mesajını gösterir:
Error Saving Revision [revision_number] ExtractVariables [policy_name]: at least one of URIPath, QueryParam, Header, FormParam, XMLPayload, JSONPayload is mandatory. Revision:[revision_number]; APIProxy:[proxy_name]; Organization:[org_name]; Environment:[env_name].
Örnek hata mesajı
Error Saving Revision 2
ExtractVariables EV-XML-Age: at least one of URIPath, QueryParam, Header, FormParam, XMLPayload, JSONPayload is mandatory.
Örnek ekran görüntüsü
Neden
Değişkenleri Ayıklama Politikası URIPath
, QueryParam
, Header
, FormParam
, XMLPayload
veya JSONPayload
öğelerinden hiçbirini içermiyorsa ayıklanacak bir şey olmadığından API Proxy'sinin dağıtımı başarısız olur.
Hata mesajında belirtildiği gibi, Değişkenleri Ayıklama politikası, politikaya şu öğelerden en az birini içermelidir: URIPath
, QueryParam
, Header
, FormParam
, XMLPayload
veya JSONPayload
.
Teşhis
Hata mesajında adı geçen Değişkenleri Ayıklama politikasını inceleyin. Politika şu öğelerden birini bile içermiyorsa: URIPath
, QueryParam
, Header
, FormParam
, XMLPayload
veya JSONPayload
, hatanın nedeni budur. Örneğin, aşağıdaki Değişkenleri Ayıklama politikası yukarıda belirtilen öğelerin hiçbirini içermez:
<ExtractVariables async="false" continueOnError="false" enabled="true" name="EV-XML-Age">
<DisplayName>EV-XML-Age</DisplayName>
<Properties/>
</ExtractVariables>
Değişkenleri Ayıklama politikasında zorunlu öğelerin hiçbiri bulunmadığından API proxy'sinin dağıtımı başarısız olur.
Çözünürlük
Değişkenleri Ayıklama politikasının şu zorunlu öğelerden en az birine sahip olduğundan emin olun: URIPath
, QueryParam
, Header
, FormParam
, XMLPayload
, JSONPayload
. Örneğin:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ExtractVariables async="false" continueOnError="false" enabled="true" name="EV-XML-Age">
<DisplayName>EV-XML-Age</DisplayName>
<Properties/>
<Source>request</Source>
<XMLPayload>
<Namespaces/>
<Variable name="age" type="integer">
<XPath>/age</XPath>
</Variable>
</XMLPayload>
</ExtractVariables>
NONEmptyPrefixMappedToEmptyURI
Hata mesajı
API proxy'sinin Edge Kullanıcı Arayüzü veya Edge management API üzerinden dağıtılması şu hata mesajını gösterir:
Error Saving Revision [revision_number] ExtractVariables [policy_name]: Non-empty prefix [prefix_name] cannot be mapped to empty uri.
Örnek hata mesajı
Error Saving Revision 3
ExtractVariables EV-XML-Age: Non-empty prefix apigee cannot be mapped to empty uri.
Örnek ekran görüntüsü
Neden
Bu hata, Değişkenleri Ayıklama Politikası, <XMLPayload>
öğesinin altındaki <Namespace>
öğesinde tanımlı bir öneke sahipse ancak URI tanımlı değilse ortaya çıkar.
Teşhis
Hatanın oluştuğu Değişkenleri Ayıklama politikasını ve ön ekin adını tanımlayın. Bu öğelerin ikisini de hata mesajında bulabilirsiniz. Örneğin, aşağıdaki hatada politika adı
EV-XML-Age
, önek deapigee
şeklindedir:ExtractVariables EV-XML-Age: Non-empty prefix apigee cannot be mapped to empty uri.
Başarısız Değişkenleri Ayıklama politikası XML'inde,
<XMLPayload>
öğesinin altındaki<Namespace>
öğesinde ayarlanan ön ek adının, hata mesajında tanımlanan ön ek adıyla (yukarıdaki 1. adım) eşleştiğini doğrulayın. Örneğin, aşağıdaki politika<Namespace>
öğesinde , hata mesajındakiyle eşleşenapigee
adlı bir önek belirtir:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <ExtractVariables async="false" continueOnError="false" enabled="true" name="EV-XML-Age"> <DisplayName>EV-XML-Age</DisplayName> <Source clearPayload="false">request</Source> <XMLPayload stopPayloadProcessing="false"> <Namespaces> <Namespace prefix="apigee"></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> </ExtractVariables>
2. adımda tanımlanan belirli ön eke sahip
<Namespace>
öğesinin geçerli bir URI'ye sahip olup olmadığını doğrulayın. URI yoksa hatanın nedeni budur.Yukarıda gösterilen Değişkenleri Ayıklama politikasındaki örnekte
apigee
ön ekine sahip<Namespace>
öğesine karşılık gelen bir URI olmadığına dikkat edin. Bu nedenle şu hatayı alırsınız:ExtractVariables EV-XML-Age: Non-empty prefix apigee cannot be mapped to empty uri.
Çözünürlük
Bir önekle tanımlanan tüm <Namespace>
öğelerinin, Değişkenleri Ayıklama politikasında karşılık gelen bir URI'ye sahip olduğundan emin olun. Örneğin:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ExtractVariables async="false" continueOnError="false" enabled="true" name="EV-XML-Age">
<DisplayName>EV-XML-Age</DisplayName>
<Source clearPayload="false">request</Source>
<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>
</ExtractVariables>
DuplicatePrefix
Hata mesajı
API proxy'sinin Edge Kullanıcı Arayüzü veya Edge management API üzerinden dağıtılması şu hata mesajını gösterir:
Error Saving Revision [revision_number] ExtractVariables [policy_name]: Duplicate prefix [prefix_name].
Örnek hata mesajı
Error Saving Revision 2
ExtractVariables EV-XML-Age: Duplicate prefix apigee.
Örnek ekran görüntüsü
Neden
Bu hata, Değişkenleri Ayıklama Politikası'ndaki aynı ön ek <XMLPayload>
öğesi altındaki <Namespace>
öğesinde birden fazla kez tanımlanmışsa ortaya çıkar.
Örneğin, bu hata, apigee
öneki aşağıda gösterildiği gibi iki kez tanımlandığından ortaya çıkar:
<Namespace prefix="apigee">http://www.apigee.com</Namespace>
<Namespace prefix="apigee">http://www.apigee.com</Namespace>
Teşhis
Hatanın oluştuğu Değişkenleri Ayıklama politikasını ve ön ekin adını tanımlayın. Bu öğelerin ikisini de hata mesajında bulabilirsiniz. Örneğin, aşağıdaki hatada politika adı
EV-XML-Age
, önek deapigee
şeklindedir:ExtractVariables EV-XML-Age: Duplicate prefix apigee.
Başarısız Değişkenleri Ayıklama politikası XML'inde,
<XMLPayload>
öğesinin altındaki<Namespace>
öğesinde ayarlanan ön ek adının, hata mesajında tanımlanan ön ek adıyla (yukarıdaki 1. adım) eşleştiğini doğrulayın. Örneğin, aşağıdaki politika<Namespace>
öğesinde , hata mesajındakiyle eşleşenapigee
adlı bir önek belirtir:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <ExtractVariables async="false" continueOnError="false" enabled="true" name="EV-XML-Age"> <DisplayName>EV-XML-Age</DisplayName> <Source clearPayload="false">request</Source> <XMLPayload stopPayloadProcessing="false"> <Namespaces> <Namespace prefix="gmail">http://mail.google.com</Namespace> <Namespace prefix="apigee">http://www.apigee.com</Namespace> <Namespace prefix="apigee">http://www.apigee.com</Namespace> </Namespaces> <Variable name="legName" type="string <XPath>/apigee:Directions/apigee:route/apigee:leg/apigee:name</XPath> </Variable> </XMLPayload> </ExtractVariables>
2. adımda tanımlanan belirli bir ön eke sahip
<Namespace>
öğesinin birden fazla kez tanımlanıp tanımlanmadığını belirleyin. Birden fazla kez tanımlanırsa hatanın nedeni budur.Yukarıda gösterilen Değişkenleri Ayıklama politikasındaki örnekte
apigee
ön ekine sahip<Namespace>
öğesinin iki kez tanımlandığına dikkat edin; Bu nedenle şu hatayı alırsınız:ExtractVariables EV-XML-Age: Duplicate prefix apigee.
Çözünürlük
Değişkenleri Ayıklama politikasındaki <Namespace>
öğelerinde her ön ek için yalnızca bir tanım olduğundan emin olun. Örneğin:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ExtractVariables async="false" continueOnError="false" enabled="true" name="EV-XML-Age">
<DisplayName>EV-XML-Age</DisplayName>
<Source clearPayload="false">request</Source>
<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>
</ExtractVariables>
NoXPathsToEvaluate
Hata mesajı
API proxy'sinin Edge Kullanıcı Arayüzü veya Edge management API üzerinden dağıtılması şu hata mesajını gösterir:
Error Saving Revision [revision_number] ExtractVariables [policy_name]:no xpaths to evaluate in variable name.
Örnek hata mesajı
Error Saving Revision 4
ExtractVariables Extract-Variables-1: no xpaths to evaluate in variable name.
Örnek ekran görüntüsü
Neden
Değişkenleri Ayıklama Politikası, <XMLPayload>
öğesi içinde <XPath>
öğesini içermiyorsa API proxy'sinin dağıtımı, yukarıda gösterilen hatayla başarısız olur.
Teşhis
Hata mesajındaki başarısız Değişkenleri Ayıklama politikasını belirleyin. Örneğin, aşağıdaki hatada politika adı
Extract-Variables-1
şeklindedir:ExtractVariables Extract-Variables-1: no xpaths to evaluate in variable name.
Başarısız Değişkenleri Ayıklama politikası XML'inde
<XPath>
alt öğesi içermeyen bir<XMLPayload>
öğesi olup olmadığını kontrol edin. Öyleyse hatanın nedeni budur.Örneğin,
<XMLPayload>
öğesi olan bir Değişkenleri Ayıklama politikası aşağıda verilmiştir:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1"> <DisplayName>Extract Variables-1</DisplayName> <Properties/> <Source clearPayload="false">request</Source> <VariablePrefix>apigee</VariablePrefix> <XMLPayload stopPayloadProcessing="false"> <Namespaces/> <Variable name="HostReachable" type="boolean"> </Variable> </XMLPayload> </ExtractVariables>
<XPath>
öğesi olmadığından API Proxy'sinin dağıtımı başarısız olur.
Çözünürlük
Değişkenleri Ayıklama politikasının, <XMLPayload>
öğesi altında tanımlanmış bir <XPath>
öğesine sahip olduğundan emin olun. Örneğin:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1">
<DisplayName>Extract Variables-1</DisplayName>
<Properties/>
<Source clearPayload="false">request</Source>
<VariablePrefix>apigee</VariablePrefix>
<XMLPayload stopPayloadProcessing="false">
<Namespaces/>
<Variable name="HostReachable" type="boolean">
<XPath>/isReachable</XPath>
</Variable>
</XMLPayload>
</ExtractVariables>
EmptyXPathExpression
Hata mesajı
API proxy'sinin Edge Kullanıcı Arayüzü veya Edge management API üzerinden dağıtılması şu hata mesajını gösterir:
Error Saving Revision [revision_number] ExtractVariables [policy_name]: XPath expression is empty in variable name.
Örnek hata mesajı
Error Saving Revision 6
ExtractVariables Extract-Variables-1: XPath expression is empty in variable name.
Örnek ekran görüntüsü
Neden
Değişkenleri Ayıklama Politikası'nın <XMLPayload>
öğesi içinde boş bir <XPath>
ifadesi varsa API proxy'sinin dağıtımı başarısız olur.
Teşhis
Hata mesajındaki başarısız Değişkenleri Ayıklama politikasını belirleyin. Örneğin, aşağıdaki hatada politika adı
Extract-Variables-1
şeklindedir:ExtractVariables Extract-Variables-1: no xpaths to evaluate in variable name.
Başarısız Değişkenleri Ayıklama politikası XML'inde, boş
<XPath>
alt öğesine sahip bir<XMLPayload>
öğesi olup olmadığını belirleyin. Öyleyse hatanın nedeni budur.Örneğin,
<XMLPayload>
öğesi olan bir Değişkenleri Ayıklama politikası aşağıda verilmiştir:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1"> <DisplayName>Extract Variables-1</DisplayName> <Properties/> <Source clearPayload="false">request</Source> <VariablePrefix>apigee</VariablePrefix> <XMLPayload stopPayloadProcessing="false"> <Namespaces/> <Variable name="address" type="string"> <XPath></XPath> </Variable> </XMLPayload> </ExtractVariables>
<XMLPayload>
öğesi içinde boş bir<XPath>
öğesi bulunduğundan API Proxy'sinin dağıtımı başarısız olur.
Çözünürlük
Değişkenleri Ayıklama politikasının <XMLPayload>
öğesi altında tanımlanmış boş olmayan ve geçerli bir <XPath>
öğesine sahip olduğundan emin olun. Örneğin:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1">
<DisplayName>Extract Variables-1</DisplayName>
<Properties/>
<Source clearPayload="false">request</Source>
<VariablePrefix>apigee</VariablePrefix>
<XMLPayload stopPayloadProcessing="false">
<Namespaces/>
<Variable name="address" type="string">
<XPath>/address</XPath>
</Variable>
</XMLPayload>
</ExtractVariables>
NoJSONPathsToEvaluate
Hata mesajı
API proxy'sinin Edge Kullanıcı Arayüzü veya Edge management API üzerinden dağıtılması şu hata mesajını gösterir:
Error Saving Revision [revision_number] ExtractVariables [policy_name]:no jsonpaths to evaluate in variable name.
Örnek hata mesajı
Error Saving Revision 6
ExtractVariables Extract-Variables-1: no jsonpaths to evaluate in variable name.
Örnek ekran görüntüsü
Neden
Değişkenleri Ayıklama Politikası, <JSONPayload>
öğesi içinde <JSONPath>
öğesini içermiyorsa API proxy'sinin dağıtımı, yukarıda gösterilen hatayla başarısız olur.
Teşhis
Hata mesajındaki başarısız Değişkenleri Ayıklama politikasını belirleyin. Örneğin, aşağıdaki hatada politika adı
Extract-Variables-1
şeklindedir:ExtractVariables Extract-Variables-1: no jsonpaths to evaluate in variable name.
Başarısız Değişkenleri Ayıklama politikası XML'inde, gerekli
<JSONPath>
alt öğesi içermeyen bir<JSONPayload>
öğesi olup olmadığını belirleyin. Öyleyse hatanın nedeni budur.Örneğin,
<JSONPayload>
öğesi içeren bir Değişkenleri Ayıklama politikası aşağıda verilmiştir:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1"> <DisplayName>Extract Variables-1</DisplayName> <Properties/> <JSONPayload> <Variable name="title"> </Variable> </JSONPayload> <Source clearPayload="false">request</Source> <VariablePrefix>apigee</VariablePrefix> </ExtractVariables>
<JSONPayload>
öğesi altında tanımlı bir<JSONPath>
alt öğesi olmadığından API Proxy'sinin dağıtımı başarısız olur.
Çözünürlük
Değişkenleri Ayıklama politikasının <JSONPayload>
öğesi altında tanımlanmış bir <JSONPath>
öğesine sahip olduğundan emin olun. Örneğin:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1">
<DisplayName>Extract Variables-1</DisplayName>
<Properties/>
<JSONPayload>
<Variable name="title">
<JSONPath>$.book.title</JSONPath>
</Variable>
</JSONPayload>
<Source clearPayload="false">request</Source>
<VariablePrefix>apigee</VariablePrefix>
</ExtractVariables>
EmptyJSONPathExpression
Hata mesajı
API proxy'sinin Edge Kullanıcı Arayüzü veya Edge management API üzerinden dağıtılması şu hata mesajını gösterir:
Error Saving Revision [revision_number] ExtractVariables [policy_name]: JSONPath expression is empty in variable name.
Örnek hata mesajı
Error Saving Revision 6
ExtractVariables Extract-Variables-1: JSONPath expression is empty in variable name.
Örnek ekran görüntüsü
Neden
Değişkenleri Ayıklama Politikası'nın <JSONPayload>
öğesi içinde boş bir <JSONPath>
ifadesi varsa API proxy'sinin dağıtımı başarısız olur.
Teşhis
Hata mesajındaki başarısız Değişkenleri Ayıklama politikasını belirleyin. Örneğin, aşağıdaki hatada politika adı
Extract-Variables-1
şeklindedir:ExtractVariables Extract-Variables-1: JSONPath expression is empty in variable name.
Başarısız Değişkenleri Ayıklama politikası XML'inde boş
<JSONPath>
alt öğesine sahip bir<JSONPayload>
öğesi olup olmadığını doğrulayın. Öyleyse hatanın nedeni budur.Örneğin,
<JSONPayload>
öğesi içeren bir Değişkenleri Ayıklama politikası aşağıda verilmiştir:<ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1"> <DisplayName>Extract Variables-1</DisplayName> <Properties/> <JSONPayload> <Variable name="account_number" type="integer"> <JSONPath></JSONPath> </Variable> </JSONPayload> <Source clearPayload="false">request</Source> <VariablePrefix>apigee</VariablePrefix> </ExtractVariables>
<JSONPayload>
öğesi içinde boş bir<JSONPath>
öğesi bulunduğundan API Proxy'sinin dağıtımı başarısız olur.
Çözünürlük
Değişkenleri Ayıklama politikasının <JSONPayload>
öğesi altında tanımlanmış boş olmayan ve geçerli bir <JSONPath>
öğesine sahip olduğundan emin olun. Örneğin:
<ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1">
<DisplayName>Extract Variables-1</DisplayName>
<Properties/>
<JSONPayload>
<Variable name="account_number" type="integer">
<JSONPath>$.account.number</JSONPath>
</Variable>
</JSONPayload>
<Source clearPayload="false">request</Source>
<VariablePrefix>apigee</VariablePrefix>
</ExtractVariables>
MissingName
Hata mesajı
API proxy'sinin Edge Kullanıcı Arayüzü veya Edge management API üzerinden dağıtılması şu hata mesajını gösterir:
Error Saving Revision [revision_number] Error occurred while validation of bean [policy_name].xml Reason: - Required attribute name is missing in [element_name]
Örnek hata mesajı
Error Saving Revision 6
Error occurred while validation of bean Extract-Variables-1.xml. Reason: - Required attribute name is missing in Variable
Örnek ekran görüntüsü
Neden
Değişkenleri Ayıklama Politikası, zorunlu olduğu durumlarda QueryParam
, Header
, FormParam
veya Variable
gibi politika öğelerinin hiçbirinde name
özelliğine sahip değilse API proxy'sinin dağıtımı başarısız olur.
Örneğin bu hata, Variable
öğesinde name
özelliği eksikse ortaya çıkar.
Teşhis
Hatanın oluştuğu Değişkenleri Ayıklama politikasının adını ve
name
özelliğinin eksik olduğu öğeyi tanımlayın. Bu öğeleri hata mesajında bulabilirsiniz. Örneğin, aşağıdaki hatada politika adıExtract-Variables-1
, öğe adı iseVariable
şeklindedir:Error occurred while validation of bean Extract-Variables-1.xml. Reason: - Required attribute name is missing in Variable
Başarısız Değişkenleri Ayıklama politikası XML'inde, yukarıdaki 1. adımda belirlenen adı taşıyan tüm öğelerin
name
özelliğinin olup olmadığını kontrol edin. Ad özelliğinin eksik olduğu bir öğe varsa hatanın nedeni budur.Örneğin, aşağıdaki Değişkenleri Ayıklama politikasında
<Variable>
öğesi tanımlanmıştır:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1"> <DisplayName>Extract Variables-1</DisplayName> <Properties/> <Variable type="boolean"> <Pattern>{isAccountActive}</Pattern> </Variable> </ExtractVariables>
Variable
öğesindename
özelliğinin eksik olduğuna, bu nedenle API Proxy'sinin dağıtımının başarısız olduğuna dikkat edin.
Çözünürlük
Değişkenleri Ayıklama Politikası'nın QueryParam
, Header
, FormParam
veya Variable
öğeleri için gerekli name
özelliğini içerdiğinden emin olun. Örneğin:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1">
<DisplayName>Extract Variables-1</DisplayName>
<Properties/>
<Variable name="account_active" type="boolean">
<Pattern>{isAccountActive}</Pattern>
</Variable>
</ExtractVariables>
PatternWithoutVariable
Hata mesajı
API proxy'sinin Edge Kullanıcı Arayüzü veya Edge management API üzerinden dağıtılması şu hata mesajını gösterir:
Error Saving Revision [revision_number] Pattern [pattern] should have at least one variable in ExtractVariables stepDefinition [policy_name]
Örnek hata mesajı
Error Saving Revision 7
Pattern /a/b/ should have at least one variable in ExtractVariables stepDefinition ExtractVariables-1.
Örnek ekran görüntüsü
Neden
Değişkenleri Ayıklama Politikası'nın <Pattern>
öğesi içinde belirtilmiş bir değişkeni yoksa API proxy'sinin dağıtımı başarısız olur. <Pattern>
öğesi, ayıklanan verilerin depolanacağı değişkenin adını gerektirir.
Teşhis
Hatanın oluştuğu Değişkenleri Ayıklama politikasının adını ve Değişkenin eksik olduğu kalıbı tanımlayın. Bu öğeleri hata mesajında bulabilirsiniz. Örneğin, aşağıdaki hatada politika adı
Extract-Variables-1
, öğe adı ise/a/b
şeklindedir:Pattern /a/b/ should have at least one variable in ExtractVariables stepDefinition ExtractVariables-1.
Başarısız Değişkenleri Ayıklama politikası XML'inde,
<Pattern>
öğesinde ayarlanan kalıbın, hata mesajında tanımlanan kalıpla eşleştiğini doğrulayın (yukarıdaki 1. adım). Örneğin, aşağıdaki politika, hata mesajındakiyle eşleşen bir/a/b
kalıbı belirtir:Örneğin, üç
<Pattern>
öğesi içeren bir Değişkenleri Ayıklama politikası aşağıda verilmiştir:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <ExtractVariables name="ExtractVariables-1"> <Source>request</Source> <URIPath> <Pattern ignoreCase="true">/a/{pathSeg}</Pattern> <Pattern ignoreCase="true">/a/b/</Pattern> <Pattern ignoreCase="true">/a/b/c/{pathSeg}</Pattern> </URIPath> <VariablePrefix>urirequest</VariablePrefix> </ExtractVariables>
2. adımda tanımlanan
<Pattern>
öğesinde değişken olup olmadığını kontrol edin. Değişkenler süslü ayraçlar içine alınmalıdır. Kalıpta değişken yoksa hatanın nedeni budur./a/b kalıbına sahip
<Pattern>
öğesi değişken içermiyor; bu nedenle API Proxy'sinin dağıtımı<Pattern ignoreCase="true">/a/b/</Pattern>
Çözünürlük
Tüm <Pattern>
öğelerinin bir değişken (kıvrık içine alınmış bir ad) içerdiğinden emin olun.
küme ayraçları). Örneğin:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<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>
</ExtractVariables>
CannotBeConvertedToNodeset
Hata mesajı
API proxy'sinin Edge Kullanıcı Arayüzü veya Edge management API üzerinden dağıtılması şu hata mesajını gösterir:
Error Deploying Revision [revision_number] ExtractVariables [policy_name]: Result of xpath [policy_name] cannot be converted to nodeset. Context Revision:[revision_number]; APIProxy:[proxy_name]; Organization:[org_name]; Environment:[env_name].
Örnek hata mesajı
Error Deploying Revision 4 to test
ExtractVariables Extract-Variables-1: Result of xpath 123 cannot be converted to nodeset. Context Revision:4;APIProxy:EV-XML;Organization:aprabhashankar-eval;Environment:test.
Örnek ekran görüntüsü
Neden
Değişkenleri Ayıklama Politikası'nda, <Variable>
türünün nodeset olarak tanımlandığı bir <XPath>
ifadesi varsa ancak ifade düğüm kümesine dönüştürülemiyorsa API proxy'sinin dağıtımı başarısız olur.
Teşhis
Hatanın oluştuğu Değişkenleri Ayıklama politikasını ve düğüm kümesine dönüştürülemeyen XPath'i tanımlayın. Bu öğelerin ikisini de hata mesajında bulabilirsiniz. Örneğin, aşağıdaki hatada politika adı
Extract-Variables-1
, XPath ise123
şeklindedir.ExtractVariables Extract-Variables-1: Result of xpath 123 cannot be converted to nodeset. Context Revision:4;APIProxy:EV-XML;Organization:aprabhashankar-eval;Environment:test.
Başarısız Değişkenleri Ayıklama politikası XML'inde,
<XPath>
öğesinde ayarlanan XPath'in, hata mesajında tanımlanan XPath ile eşleştiğini doğrulayın (yukarıdaki 1. adım). Örneğin, aşağıdaki politikadeğerini, hata mesajındakiyle eşleşen 123
olarak belirtir:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1"> <DisplayName>Extract Variables-1</DisplayName> <Properties/> <Source clearPayload="false">request</Source> <VariablePrefix>visitor</VariablePrefix> <XMLPayload stopPayloadProcessing="false"> <Namespaces/> <Variable name="age" type="nodeset"> <XPath>123</XPath> </Variable> </XMLPayload> </ExtractVariables>
Yukarıdaki 2. adımda tanımlanan
<XPath>
öğesine karşılık gelen<Variable>
öğesinin türünü inceleyin.<Variable>
türünodeset
ise hatanın nedeni budur.Örnek Değişkenleri Ayıklama politikasında
<XPath>
ifadesinin123
olduğuna dikkat edin.<XPath>123</XPath>
123
ifadesi, düğüm kümesine dönüştürülemez. Bu nedenle API Proxy'sinin dağıtımı başarısız olur.
Çözünürlük
<Variable>
türü düğüm kümesi olarak tanımlanırsa Değişkenleri Ayıklama politikasında kullanılan <XPath>
ifadelerinin düğüm kümesine dönüştürülebildiğinden emin olun. Örneğin:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract-Variables-1">
<DisplayName>Extract Variables-1</DisplayName>
<Properties/>
<Source clearPayload="false">request</Source>
<VariablePrefix>visitor</VariablePrefix>
<XMLPayload stopPayloadProcessing="false">
<Namespaces/>
<Variable name="age" type="nodeset">
<XPath>/visitor/age</XPath>
</Variable>
</XMLPayload>
</ExtractVariables>
InvalidPattern
Hata mesajı
API proxy'sinin Edge Kullanıcı Arayüzü veya Edge management API üzerinden dağıtılması şu hata mesajını gösterir:
Error Deploying Revision [revision_number]
Pattern [pattern] is invalid in ExtractVariables stepDefinition [policy_name]
Örnek hata mesajı
Error Deploying Revision 18 to test
Pattern {*} is invalid in ExtractVariables stepDefinition ExtractVariables-2.
Örnek ekran görüntüsü
Neden
Değişkenleri Ayıklama Politikası'ndaki URIPath
, QueryParam
, Header
, FormParam
, XMLPayload
veya JSONPayload
gibi öğelerde <Pattern>
öğe tanımı geçersizse API proxy'sinin dağıtımı başarısız olur.
Teşhis
Hata mesajından başarısız olan Değişkenleri Ayıklama politikasını belirleyin. Örneğin, aşağıdaki hatada politika adı
Extract-Variables-2
şeklindedir:Pattern {*} is invalid in ExtractVariables stepDefinition ExtractVariables-2.
Başarısız Değişkenleri Ayıklama politikası XML'inde bu öğelerden herhangi birinin mevcut olup olmadığını kontrol edin ve bir
<Pattern>
öğesi ekleyin.URIPath
,QueryParam
,Header
,FormParam
,XMLPayload
veyaJSONPayload
.Örneğin,
<QueryParam>
öğesi içinde<Pattern>
öğesi bulunan bir Değişkenleri Ayıklama politikası örneğini burada görebilirsiniz:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <ExtractVariables name="ExtractVariables-2"> <DisplayName>ExtractVariables-2</DisplayName> <Source>request</Source> <QueryParam name="code"> <Pattern ignoreCase="true">{*}</Pattern> </QueryParam> <VariablePrefix>queryinfo</VariablePrefix> </ExtractVariables>
Her
<Pattern>
öğesinin tanımını inceleyin. Geçersiz tanımı olan bir<Pattern>
öğesi varsa hatanın nedeni budur.Yukarıda gösterilen Değişkenleri Ayıklama politikasındaki örnekte,
<QueryParam>
öğesindeki<Pattern>
tanımının geçersiz olduğuna dikkat edin; bu nedenle API Proxy'sinin dağıtımı başarısız olur. Şu kaynakları da inceleyin Eşleme ve değişken oluşturma hakkında<Pattern ignoreCase="true">{*}</Pattern>
Çözünürlük
Değişkenleri Ayıklama politikasındaki URIPath
, QueryParam
, Header
, FormParam
, XMLPayload
veya JSONPayload
öğelerindeki <Pattern>
öğe tanımının geçerli olduğundan emin olun. Örneğin:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ExtractVariables name="ExtractVariables-2">
<DisplayName>Extract a value from a query parameter</DisplayName>
<Source>request</Source>
<QueryParam name="code">
<Pattern ignoreCase="true">{code}</Pattern>
</QueryParam>
<VariablePrefix>queryinfo</VariablePrefix>
</ExtractVariables>
Eşleme ve değişken oluşturma hakkında başlıklı makaleyi de inceleyin
XPathCompilationFailed
Hata mesajı
API proxy'sinin Edge Kullanıcı Arayüzü veya Edge management API üzerinden dağıtılması başarısız şu hata mesajıyla:
Error Deploying Revision [revision_number] ExtractVariables [policy_name]: Failed to compile xpath [xpath] Context Revision:[revision_number]; APIProxy:[proxy_name]; Organization:[org_name]; Environment:[env_name].
Örnek hata mesajı
Error Deploying Revision 1 to test
ExtractVariables EV-XML-Age: Failed to compile xpath /apigee:Directions/apigee:route/apigee:leg/apigee:name. Context Revision:1;APIProxy:EV-XML;Organization:aprabhashankar-eval;Environment:test.
Örnek ekran görüntüsü
Neden
<XPath>
öğesinde kullanılan önek veya değer, Değişkenleri Ayıklama Politikası'nda bildirilen ad alanlarının hiçbirinin parçası değilse API proxy'sinin dağıtımı başarısız olur.
Ad alanları, XPath ve ön ek hakkında daha fazla bilgiyi XML Ad Alanları ve XPath ve XSLT'yi Nasıl Etkiledikleri bölümünde bulabilirsiniz.
Teşhis
Hatanın oluştuğu Değişkenleri Ayıklama politikasını ve derlenemeyen XPath'i tanımlayın. Bu öğelerin ikisini de hata mesajında bulabilirsiniz. Örneğin, aşağıdaki hatada politika adı
EV-XML-Age
, xpath ise/apigee:Directions/apigee:route/apigee:leg/apigee:name
şeklindedir.ExtractVariables EV-XML-Age: Failed to compile xpath /apigee:Directions/apigee:route/apigee:leg/apigee:name. Context Revision:1;APIProxy:EV-XML;Organization:aprabhashankar-eval;Environment:test.
Başarısız Değişkenleri Ayıklama politikası XML'inde,
<XPath>
öğesinde ayarlanan XPath'in, hata mesajında tanımlanan XPath ile eşleştiğini doğrulayın (yukarıdaki 1. adım). Örneğin, aşağıdaki politikadeğerini, hata mesajındakiyle eşleşen /apigee:Directions/apigee:route/apigee:leg/apigee:name
olarak belirtir:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <ExtractVariables async="false" continueOnError="false" enabled="true" name="EV-XML-Age"> <DisplayName>EV-XML-Age</DisplayName> <Source clearPayload="false">request</Source> <XMLPayload stopPayloadProcessing="false"> <Namespaces> <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> </ExtractVariables>
Değişkenleri Ayıklama politikasındaki
<Namespaces>
ve<XPath>
öğelerini inceleyin. Hata mesajında belirtilen<XPath>
, Değişkenleri Ayıklama politikasında belirtilen ad alanlarının parçası olmayan bir önek veya değer kullanıyorsa hatanın nedeni budur.Belirli
<XPath>
değerinin, örnek Değişkenler Politikası'ndakiapigee
önekini kullandığına dikkat edin.<XPath>/apigee:Directions/apigee:route/apigee:leg/apigee:name</XPath>
Bununla birlikte,
apigee
öneki<Namespace>
öğelerinin hiçbirinde tanımlı değildir; bu nedenle<XPath>
derlemesinin başarısız olması dağıtım hatasına neden olur.
Çözünürlük
<XPath>
öğelerinde kullanılan tüm ad alanlarının Değişkenleri Ayıklama Politikası'nda belirtildiğinden emin olun. Örneğin:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ExtractVariables async="false" continueOnError="false" enabled="true" name="EV-XML-Age">
<DisplayName>EV-XML-Age</DisplayName>
<Source clearPayload="false">request</Source>
<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>
</ExtractVariables>