您正在查看 Apigee 和 Apigee Hybrid 說明文件。
    查看 
    Apigee Edge 說明文件。
SourceUnavailable
錯誤代碼
steps.xml2json.SourceUnavailable
錯誤回應主體
{ "fault": { "faultstring": "XMLToJSON[policy_name]: Source [source_variable] is not available", "detail": { "errorcode": "steps.xmltojson.SourceUnavailable" } } }
錯誤訊息範例
{
    "fault": {
        "faultstring": "XMLToJSON[Convert-XMLToJSON]: Source response is not available",
        "detail": {
            "errorcode": "steps.xml2json.SourceUnavailable"
        }
    }
}
原因
如果 XML 到 JSON 政策的 <Source> 元素中指定的 message 或字串變數為下列任一情況,就會發生這個錯誤:
- 超出範圍 (在執行政策的特定流程中不可用),或
- 無法解析 (未定義)
舉例來說,如果 XML 到 JSON 政策應在要求流程中執行,但 <Source> 元素設為 response 變數,而該變數不存在於要求流程中,就會發生這項錯誤。
診斷
- 找出發生錯誤的 XML 到 JSON 政策,以及無法使用的變數名稱。您可以在錯誤回應的 - faultstring元素中找到這兩項項目。例如,在以下- faultstring中,政策名稱為- Convert-XMLToJSON,變數為- response:- "faultstring": "XMLToJSON[Convert-XMLToJSON]: Source response is not available"
- 在 XML 至 JSON 政策 XML 轉換失敗的情況下,請確認 - <Source>元素中設定的變數名稱與錯誤字串中指出的變數名稱相符 (請參閱上述步驟 1)。舉例來說,下列 XML 到 JSON 政策會在- <Source>元素中指定名為- response的變數,與- faultstring中的變數相符:- <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <XMLToJSON async="false" continueOnError="false" enabled="true" name="Convert-XMLToJSON"> <DisplayName>Convert-XMLToJSON</DisplayName> <Properties/> <Format>google</Format> <OutputVariable>response</OutputVariable> <Source>response</Source> </XMLToJSON>
- 判斷 - <Source>元素中使用的變數是否已定義,且在執行 XML 至 JSON 政策的流程中可用。
- 如果變數為: - 超出範圍 (在執行政策的特定流程中不可用),或
- 無法解析 (未定義)
 - 則表示這是錯誤的原因。 - 舉例來說,假設上述 XML 到 JSON 政策應在要求流程中執行。請注意, - response變數會用於 XML 到 JSON 政策的- <Source>元素中。回應變數僅適用於回應流程。- 由於回應變數不在要求流程中,因此您會收到以下錯誤代碼: - steps.xml2json.SourceUnavailable
解決方法
請確認在失敗的 XML 至 JSON 政策的 <Source> 元素中設定的變數已定義,且在政策執行的流程中存在。
如要修正上述 XML 至 JSON 政策範例,您可以修改 <Source> 元素,以便使用要求流程中的 request 變數:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<XMLToJSON async="false" continueOnError="false" enabled="true" name="Convert-XMLToJSON">
    <DisplayName>Convert-XMLToJSON</DisplayName>
    <Properties/>
    <Format>google</Format>
    <OutputVariable>response</OutputVariable>
    <Source>request</Source>
</XMLToJSON>
ExecutionFailed
錯誤代碼
steps.xml2json.ExecutionFailed
錯誤回應主體
{ "fault": { "faultstring": "XMLToJSON[policy_name]: Execution failed. reason: Premature end of document while parsing at line [line_number](possibly around char [character_number])", "detail": { "errorcode": "steps.xml2json.ExecutionFailed" } } }
可能原因
導致這項錯誤的可能原因包括:
| 原因 | 說明 | 
| 缺少輸入酬載 | 輸入酬載 (XML) 為空白。 | 
| 無效或格式不正確的輸入內容 | 傳送至 XML 到 JSON 政策的輸入內容 (XML) 無效或格式錯誤。 | 
原因:缺少輸入酬載
在 XML 到 JSON 政策中,如果 <Source> 元素中指定的變數內容 (酬載) 為空白,就會發生此錯誤。
舉例來說,如果 XML 到 JSON 政策中的 <Source> 元素設為 request 或 response 變數,且應包含 XML 酬載,則如果酬載為空白,就會發生這個錯誤。
診斷
- 找出發生錯誤的 XML 到 JSON 政策。您可以在錯誤回應的 - faultstring元素中找到這項資訊。例如,在以下- faultstring中,政策名稱為- Convert-XMLToJSON:- "faultstring": "XMLToJSON[Convert-XMLToJSON]: Execution failed. reason: Premature end of document while parsing at line 1(possibly around char 0)"
- 請檢查 XML 到 JSON 政策 XML 轉換失敗的 - <Source>元素,並判斷指定的變數。例如,下列 XML 到 JSON 政策已將- <Source>元素設為要求:- <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <XMLToJSON async="false" continueOnError="false" enabled="true" name="Convert-XMLToJSON"> <DisplayName>Convert-XMLToJSON</DisplayName> <Properties/> <Options> <RecognizeNumber>true</RecognizeNumber> <RecognizeBoolean>true</RecognizeBoolean> <RecognizeNull>true</RecognizeNull> </Options> <OutputVariable>request</OutputVariable> <Source>request</Source> </XMLToJSON>
- 請檢查 XMLToJSON 政策中 - <Source>元素指定的變數是否為空白。如果是空白,則表示這是錯誤的原因。- 在上方的 XML 到 JSON 政策範例中,用戶端傳送的請求酬載 (即要求主體) 為空白。 - 例如: - curl -v "http://your_host_alias/v1/testxmltojson" -H "Content-Type: application/xml" - 其中 your_host_alias 是用於存取 API 的公開網域,如覆寫檔案中的 - virtualhosts.hostAliases屬性所定義。請參閱「指定設定值覆寫值」。- 由於 XML 要求酬載為空白,您會收到以下錯誤代碼: - steps.xml2json.ExecutionFailed- 如果 - <Source>元素設為回應,但後端伺服器傳遞空白酬載,也會發生這項錯誤。
解決方法
請確認透過 <Source> 元素傳遞至 XML 至 JSON 政策的輸入內容是有效的 XML 酬載,且非空白。
如要修正 XML 到 JSON 政策範例的問題,請傳遞有效的 XML 酬載。例如:
- 建立名為 city.xml 的檔案,其中含有下列內容: - <?xml version="1.0" encoding="UTF-8"?> <root> <City>Bengaluru</City> <Name>Apigee</Name> <Pincode>560016</Pincode> </root>
- 使用 cURL 指令發出 API 呼叫,如下所示: - curl -v "http://your_host_alias/v1/testxmltojson" -H "Content-Type: application/xml" -X POST -d @company.xml - 其中 your_host_alias 是用於存取 API 的公開網域,如覆寫檔案中的 - virtualhosts.hostAliases屬性所定義。請參閱「指定設定值覆寫值」。
原因:輸入內容無效或格式不正確
如果 XML 到 JSON 政策剖析無效或格式不正確的輸入內容,就會發生這個錯誤。
舉例來說,如果您將下列無效的 XML 做為 XML 到 JSON 政策的輸入內容,
<?xml version="1.0" encoding="UTF-8"?>
<root>
   <City>Bengaluru</City>
   <Name>Apigee</Name>
   <Pincode>560016</Pincode>
您會收到以下錯誤訊息:
"faultstring": "XMLToJSON[Convert-XMLToJSON]: Execution failed. reason: Premature end of document while parsing at line 6(possibly  around char 0)"
診斷
- 找出發生錯誤的 XML 到 JSON 政策。您可以在錯誤回應的 - faultstring元素中找到這項資訊。例如,在以下- faultstring中,政策名稱為- Convert-XMLToJSON:- "faultstring": "XMLToJSON[Convert-XMLToJSON]: Execution failed. reason: Premature end of document while parsing at line 6(possibly around char 0)"
- 請檢查失敗的 XML 到 JSON 政策 XML 中指定的 - <Source>元素。舉例來說,下列 XML 到 JSON 政策將- <Source>元素設為- request變數:- <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <XMLToJSON async="false" continueOnError="false" enabled="true" name="Convert-XMLToJSON"> <DisplayName>Convert-XMLToJSON</DisplayName> <Properties/> <Options> <RecognizeNumber>true</RecognizeNumber> <RecognizeBoolean>true</RecognizeBoolean> <RecognizeNull>true</RecognizeNull> </Options> <OutputVariable>request</OutputVariable> <Source>request</Source> </XMLToJSON>
- 驗證 XML 至 JSON 政策 - <Source>元素中指定的輸入內容是否為有效的 XML 酬載。如果輸入值無效或格式錯誤,就會導致錯誤。- 在上述 XML 到 JSON 政策範例中,系統透過 - city.xml檔案將下列無效的 XML 傳遞至「提取變數」政策:- <?xml version="1.0" encoding="UTF-8"?> <root> <City>Bengaluru</City> <Name>Apigee</Name> <Pincode>560016</Pincode>- 以下是示範如何傳送要求的 API 呼叫: - curl -v "http://your_host_alias/v1/testxmltpjson" -H "Content-Type: application/xml" -X POST -d @city.xml - 其中 your_host_alias 是用於存取 API 的公開網域,如覆寫檔案中的 - virtualhosts.hostAliases屬性所定義。請參閱「指定設定值覆寫值」。- 傳遞至 API 的 XML 酬載無效,因為 XML 沒有 - <root>元素的結尾標記。因此,您會收到以下錯誤代碼:- steps.xml2json.ExecutionFailed- 如果 - <Source>元素設為回應,但後端伺服器的 XML 回應酬載無效或格式錯誤,也會發生這項錯誤。
解決方法
請確認透過 <Source> 元素傳遞至 XML 至 JSON 政策的輸入內容有效且格式正確。
如要修正上述 XML 到 JSON 政策範例的問題,請傳遞有效的 XML 酬載要求,如下所示:
<?xml version="1.0" encoding="UTF-8"?>
<root>
   <City>Bengaluru</City>
   <Name>Apigee</Name>
   <Pincode>560016</Pincode>
</root>
OutputVariableIsNotAvailable
錯誤代碼
steps.xml2json.OutputVariableIsNotAvailable
錯誤回應主體
{ "fault": { "faultstring": "XMLToJSON[policy_name]: Output variable is not available.", "detail": { "errorcode": "steps.xml2json.OutputVariableIsNotAvailable" } } }
錯誤訊息範例
{
    "fault": {
        "faultstring": "XMLToJSON[Convert-XMLToJSON]: Output variable is not available.",
        "detail": {
            "errorcode": "steps.xml2json.OutputVariableIsNotAvailable"
        }
    }
}
原因
如果 XML 到 JSON 政策的 <Source> 元素中指定的變數為字串類型,且未定義 <OutputVariable> 元素,就會發生這項錯誤。如果 <Source> 元素中定義的變數為 string 類型,則必須使用 <OutputVariable> 元素。
診斷
- 找出發生錯誤的 XML 到 JSON 政策。您可以在錯誤回應的 - faultstring元素中找到這項資訊。例如,在以下- faultstring中,政策名稱為- Convert-XMLToJSON:- "faultstring": "XMLToJSON[Convert-XMLToJSON]: Output variable is not available."
- 在 XML 至 JSON 政策驗證失敗的情況下,檢查是否缺少 - <OutputVariable>。- 以下是 XML 到 JSON 政策的範例,其中缺少 - <OutputVariable>元素。- <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <XMLToJSON async="false" continueOnError="false" enabled="true" name="Convert-XMLToJSON"> <DisplayName>Convert-XMLToJSON</DisplayName> <Properties/> <Format>google</Format> <Source>TrackingNumber</Source> </XMLToJSON>
- 判斷 - <Source>元素中指定的變數類型:- 找出 API Proxy 套件中的程式碼,該程式碼會先定義變數。
- 找出先定義及填入變數的政策後,您需要依下列方式判斷該變數的類型:
- 檢查 type 屬性值 (如有)。
- 如果沒有 type 屬性,系統會將變數視為字串。
 
- 如果變數的類型為 string,則是錯誤的原因。如要瞭解常見的變數及其類型,請參閱變數參考資料。
 - 舉例來說,請查看上述 XML 到 JSON 政策中的 TrackingNumber 變數。其類型為字串。請考慮使用指派訊息政策,將值設為名為 - TrackingNumber的變數,如下所示:- <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <AssignMessage async="false" continueOnError="false" enabled="true" name="Assign_TrackingNumber"> <DisplayName>Assign_TrackingNumber</DisplayName> <Properties/> <AssignVariable> <Name>TrackingNumber</Name> <Value><![CDATA[<Code>560075393539898</Code>]]></Value> <Ref/> </AssignVariable> <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables> <AssignTo createNew="false" transport="http" type="request"/> </AssignMessage>- 請注意,透過 - <AssignVariable>設定的變數類型為字串。因此變數- TrackingNumber的型別為字串。- 請回想一下, - TrackingNumber變數是在 XML 轉 JSON 政策的- <Source>元素中使用:- <Source>TrackingNumber</Source>- 由於 - TrackingNumber屬於字串類型,且政策中缺少- <OutputVariable>,因此您會收到以下錯誤代碼:- steps.xml2json.OutputVariableIsNotAvailable
解決方法
請確認如果 XMLToJSON 政策的 <Source> 元素中指定的變數為字串類型,則在這種情況下必須使用 <OutputVariable> 元素。
如要修正上述的 XML 至 JSON 政策,請加入 <OutputVariable> 元素,如下所示。
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<XMLToJSON async="false" continueOnError="false" enabled="true" name="Convert-XMLToJSON">
    <DisplayName>Convert-XMLToJSON</DisplayName>
    <Properties/>
    <Format>google</Format>
    <OutputVariable>response</OutputVariable>
    <Source>TrackingNumber</Source>
</XMLToJSON>
InCompatibleTypes
錯誤代碼
steps.xml2json.InCompatibleTypes
錯誤回應主體
{ "fault": { "faultstring": "XMLToJSON[policy_name]: String can not be assigned to message type.", "detail": { "errorcode": "steps.xml2json.InCompatibleTypes" } } }
錯誤訊息範例
{
    "fault": {
        "faultstring": "XMLToJSON[XMLToJSON_CheckType]: String can not be assigned to message type.",
        "detail": {
            "errorcode": "steps.xml2json.InCompatibleTypes"
        }
    }
}
原因
如果 <Source> 元素和 <OutputVariable> 元素中定義的變數類型不一致,就會發生此錯誤。<Source> 元素和 <OutputVariable> 元素中包含的變數類型必須一致。
The valid types are message and string.
診斷
- 找出發生錯誤的 XML 到 JSON 政策。您可以在錯誤回應的 - faultstring元素中找到這項資訊。例如,在以下- faultstring中,政策名稱為- XMLToJSON_CheckType:- "faultstring": "XMLToJSON[XMLToJSON_CheckType]: String can not be assigned to message type."
- 在 XML 轉換為 JSON 政策中,請注意 - <OutputVariable>中指定的值。- 以下是缺少 - <OutputVariable>元素的 XMLToJSON 政策範例- <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <XMLToJSON async="false" continueOnError="false" enabled="true" name="XMLToJSON_CheckType"> <DisplayName>XMLToJSON_CheckType</DisplayName> <Properties/> <Format>google</Format> <OutputVariable>request</OutputVariable> <Source>TrackingNumber</Source> </XMLToJSON>
- 判斷 - <Source>和- <OutputVariable>元素中指定的變數類型:- 找出 API Proxy 套件中的程式碼,其中會先定義這些變數。
- 找出先定義及填入變數的政策後,您需要依下列方式判斷該變數的類型:
- 檢查 type 屬性值 (如有)。
- 如果沒有 type 屬性,系統會將變數視為字串。
 
- 如果 <Source>中指定的變數類型為string,而<OutputVariable>的類型為 message,或反之,則為錯誤原因。如要瞭解常見的變數及其類型,請參閱變數參考資料。
 - 舉例來說,請考慮使用「指派訊息」政策,將值設為名為 - TrackingNumber的變數,如下所示:- <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <AssignMessage async="false" continueOnError="false" enabled="true" name="Assign_TrackingNumber"> <DisplayName>Assign_TrackingNumber</DisplayName> <Properties/> <AssignVariable> <Name>TrackingNumber</Name> <Value><![CDATA[<Code>560075393539898</Code>]]></Value> <Ref/> </AssignVariable> <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables> <AssignTo createNew="false" transport="http" type="request"/> </AssignMessage>- 請注意,透過 - <AssignVariable>設定的變數類型為字串。因此變數- TrackingNumber的型別為字串。- 請回想一下, - TrackingNumber變數會用於 XMLToJSON 政策的- <Source>元素:- <Source>TrackingNumber</Source>- 同樣地,請回想一下, - request變數會用於 XML 到 JSON 政策的- <OutputVariable>元素:- <OutputVariable>request</OutputVariable>- 由於 - TrackingNumber屬於- string類型,而- response變數屬於- message類型,因此兩者不相容,因此您會收到錯誤代碼:- steps.xml2json.InCompatibleTypes- 如果 - <Source>元素中的變數為- message類型,但- <OutputVariable>元素中的變數為字串類型,也會發生上述錯誤。
解決方法
請確認 <Source> 元素和 <OutputVariable> 元素中定義的變數類型一律相同。<Source> 元素和 <OutputVariable> 元素中包含的變數類型必須一致。
如要修正上述的 XML 至 JSON 政策,您可以使用指派訊息政策宣告另一個 string 型別的變數 TrackingNumber_output,並在 XML 至 JSON 政策的 <OutputVariable> 元素中使用這個變數。
修改的「指派訊息」政策:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<AssignMessage async="false" continueOnError="false" enabled="true" name="Assign_TrackingNumber">
    <DisplayName>Assign_TrackingNumber</DisplayName>
    <Properties/>
    <AssignVariable>
        <Name>TrackingNumber</Name>
        <Value><![CDATA[<Code>560098</Code>]]></Value>
        <Ref/>
    </AssignVariable>
    <AssignVariable>
        <Name>TrackingNumber_output</Name>
        <Ref/>
    </AssignVariable>
    <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
    <AssignTo createNew="false" transport="http" type="request"/>
</AssignMessage>
已修改的 XMLToJSON 政策:
  <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
  <XMLToJSON async="false" continueOnError="false" enabled="true" name="XMLToJSON_CheckType">
      <DisplayName>XMLToJSON_CheckType</DisplayName>
      <Properties/>
      <Format>google</Format>
      <OutputVariable>TrackingNumber_output</OutputVariable>
      <Source>TrackingNumber</Source>
  </XMLToJSON>
InvalidSourceType
錯誤代碼
steps.xml2json.InvalidSourceType
錯誤回應主體
{ "fault": { "faultstring": "XMLToJSON[class invalid_class]: Invalid source type class invalid_class. Valid source types are [message, string].", "detail": { "errorcode": "steps.xml2json.InvalidSourceType" } } }
錯誤訊息範例
{
    "fault": {
        "faultstring": "XMLToJSON[class java.lang.Integer]: Invalid source type class java.lang.Integer. Valid source types are [message, string].",
        "detail": {
            "errorcode": "steps.xml2json.InvalidSourceType"
        }
    }
}
原因
如果用於定義 <Source> 元素的變數類型無效,就會發生這個錯誤。有效的變數類型為 message 和 string。
診斷
- 找出 XML 到 JSON 政策中使用的無效來源類型。您可以在錯誤訊息中找到這項資訊。舉例來說,在以下錯誤中,無效的類型是整數。 - "faultstring": "XMLToJSON[class java.lang.Integer]: Invalid source type class java.lang.Integer. Valid source types are [message, string]."
- 請檢查發生失敗的特定 API Proxy 中,所有 XML 到 JSON 政策。在失敗的 XML 至 JSON 政策中,請注意 - <Source>中指定的變數名稱。- <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <XMLToJSON async="false" continueOnError="false" enabled="true" name="XMLToJSON_CheckType"> <DisplayName>XMLToJSON_CheckType</DisplayName> <Properties/> <Format>google</Format> <OutputVariable>response</OutputVariable> <Source>BookCode</Source> </XMLToJSON>
- 判斷 - <Source>元素中指定的變數類型:- 找出 API Proxy 套件中的程式碼,這個變數會先在其中定義。
- 找出先定義及填入變數的政策後,您需要依下列方式判斷該變數的類型:
- 檢查 type 屬性值 (如有)。
- 如果沒有 type 屬性,系統會將變數視為字串。
 
- 如果 <Source>中指定的變數類型既不是message也不是string類型,則會導致錯誤。如要瞭解常見的變數及其類型,請參閱變數參考資料。
 - 舉例來說,請考量 ExtractVariables 政策,用於從 XML 酬載擷取值,並將值設為 - BookCode變數,以便成為- integer類型,如下所示:- <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <ExtractVariables async="false" continueOnError="false" enabled="true" name="Extract_BookCode"> <DisplayName>Extract_BookCode</DisplayName> <Properties/> <Source>request</Source> <XMLPayload stopPayloadProcessing="false"> <Variable name="BookCode" type="integer"> <XPath>/root/BookCode</XPath> </Variable> </XMLPayload> </ExtractVariables>- 請回想一下, - BookCode變數是在 XML 轉 JSON 政策的- <Source>元素中使用:- <Source>BookCode</Source>- 由於這個變數的類型為 - Integer,而非有效的- <Source>類型,因此 API Proxy 會失敗並顯示以下錯誤:- steps.xml2json.InvalidSourceType
解決方法
請確認用來指定 <Source> 元素的變數類型是否有效。有效的 <Source> 類型為 message 和 string。
為避免 XML 轉 JSON 政策發生上述錯誤,您可以使用 request 變數,該變數的類型為 message,或任何有效的 XML 酬載字串。