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şenapigeeadlı 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şenapigeeadlı 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ı'nın <XMLPayload> öğesi içinde <XPath> öğesi yoksa 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 VariableBaş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/bkalı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 123olarak 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ünodesetise hatanın nedeni budur.Örnek Değişkenleri Ayıklama politikasında
<XPath>ifadesinin123olduğuna dikkat edin.<XPath>123</XPath>123ifadesi, 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,XMLPayloadveyaJSONPayload.Ö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:nameolarak 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>