本頁內容適用於 Apigee 和 Apigee Hybrid。
查看
Apigee Edge 說明文件。
HTTPModifier 政策會變更現有的要求或回應訊息。
這項政策可讓您對這些郵件執行下列動作:
使用 HTTPModifier,您可以新增、變更或移除要求或回應的屬性。或者,您也可以使用 HTTPModifier 建立自訂要求或回應訊息,並將其傳遞至替代目標,詳情請參閱「建立自訂要求訊息」。
HTTPModifier 政策可使用下列子項元素建立流程變數:
<Add>、<Set> 和 <Remove> 元素的排列順序十分重要。政策會按照政策設定中的順序執行這些動作。如要移除所有標頭,請設定特定標頭,並在 <Set> 元素前加入 <Remove> 元素。
這項政策是標準政策,可部署至任何環境類型。如要瞭解各環境類型適用的政策類型和可用性,請參閱「政策類型」。
<HTTPModifier> 元素
定義 HTTPModifier 政策。
| 預設值 | 請參閱下方的「預設政策」分頁 |
| 必填與否 | 必填 |
| 類型 | 複雜物件 |
| 父項元素 | 不適用 |
| 子元素 |
<Add><AssignTo><DisplayName><IgnoreUnresolvedVariables><Remove><Set> |
<HTTPModifier> 元素使用下列語法:
語法
<HTTPModifier> 元素使用下列語法:
<HTTPModifier continueOnError="[false|true]" enabled="[true|false]" name="POLICY_NAME" > <!-- All HTTPModifier child elements are optional --> <Add> <FormParams> <FormParam name="FORMPARAM_NAME">FORMPARAM_VALUE</FormParam> ... </FormParams> <Headers> <Header name="HEADER_NAME">HEADER_VALUE</Header> ... </Headers> <QueryParams> <QueryParam name="QUERYPARAM_NAME">QUERYPARAM_VALUE</QueryParam> ... </QueryParams> </Add> <AssignTo createNew="[true|false]" transport="http" type="[request|response]">DESTINATION_VARIABLE_NAME</AssignTo> <DisplayName>POLICY_DISPLAY_NAME</DisplayName> <IgnoreUnresolvedVariables>[true|false]</IgnoreUnresolvedVariables> <!-- Can also be empty to remove everything from the message (<Remove/>) --> <Remove> <!-- Can also be an empty array to remove all FormParams (<FormParams/>) --> <FormParams> <FormParam name="FORMPARAM_NAME">FORMPARAM_VALUE</FormParam> ... </FormParams> <!-- Can also be an empty array to remove all Headers (<Headers/>) --> <Headers> <Header name="HEADER_NAME">HEADER_VALUE</Header> ... </Headers> <!-- Can also be an empty array to remove all QueryParams (<QueryParams/>) --> <QueryParams> <QueryParam name="QUERYPARAM_NAME">QUERYPARAM_VALUE</QueryParam> ... </QueryParams> </Remove> <Set> <FormParams> <FormParam name="FORMPARAM_NAME">FORMPARAM_VALUE</FormParam> ... </FormParams> <Headers> <Header name="HEADER_NAME">HEADER_VALUE</Header> ... </Headers> <Path>PATH</Path> <QueryParams> <QueryParam name="QUERYPARAM_NAME">QUERYPARAM_VALUE</QueryParam> ... </QueryParams> <StatusCode>HTTP_STATUS_CODE or {variable}</StatusCode> <Verb>[GET|POST|PUT|PATCH|DELETE|{variable}]</Verb> <Version>[1.0|1.1|{variable}]</Verb> </Set> </HTTPModifier>
預設政策
以下範例顯示在 Apigee UI 中將 HTTPModifier 政策新增至流程時的預設設定:
<HTTPModifier continueOnError="false" enabled="true" name="http-modifier-default"> <DisplayName>HTTP Modifier-1</DisplayName> <Properties/> <Remove> <Headers> <Header name="h1"/> </Headers> <QueryParams> <QueryParam name="q1"/> </QueryParams> <FormParams> <FormParam name="f1"/> </FormParams> </Remove> <Add> <Headers/> <QueryParams/> <FormParams/> </Add> <Set> <Headers/> <QueryParams/> <FormParams/> <!-- <Verb>GET</Verb> --> <Path/> </Set> <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables> <AssignTo createNew="false" transport="http" type="request"/> </HTTPModifier>
在 Apigee UI 中插入新的 HTTPModifier 政策時,範本會包含所有可能作業的存根。通常,您會選取要透過這項政策執行的作業,並移除其餘子元素。舉例來說,如要執行新增作業,請使用 <Add> 元素,並從政策中移除 <Remove> 和其他子項元素,讓政策更容易閱讀。
這個元素包含下列所有政策都適用的屬性:
| 屬性 | 預設 | 是否必要? | 說明 |
|---|---|---|---|
name |
不適用 | 必要 |
政策的內部名稱。 您可以選擇使用 |
continueOnError |
false | 選用 | 將其設為 false,即可在政策失敗時傳回錯誤。這是大多數政策的預期行為。將其設為 true,即使政策失敗,流程執行作業仍會繼續進行。另請參閱:
|
enabled |
是 | 選用 | 設為 true 即可強制執行政策。設為 false 即可關閉政策。即使政策仍附加至流程,系統也不會強制執行這項政策。 |
async |
false | 已淘汰 | 此屬性已淘汰。 |
下表簡要說明 <HTTPModifier> 的子元素:
| 子元素 | 是否必要 | 說明 |
|---|---|---|
| 常見作業 | ||
<Add> |
選用 | 將資訊新增至 <AssignTo> 元素指定的訊息物件。
如要覆寫現有標頭或參數,請使用 |
<Remove> |
選用 | 從 <AssignTo> 元素中指定的訊息變數刪除指定元素。 |
<Set> |
選用 | 取代要求或回應中現有屬性的值,由 <AssignTo> 元素指定。
|
| 其他子元素 | ||
<AssignTo> |
選用 | 指定 HTTPModifier 政策要處理的訊息。這可以是標準要求或回應,也可以是新的自訂訊息。 |
<IgnoreUnresolvedVariables> |
選用 | 判斷遇到無法解析的變數時,是否要停止處理。 |
後續章節將說明這些子元素。
範例
下列範例顯示 HTTPModifier 政策的幾種用法:
1:新增標頭
以下範例會使用 <Add> 元素,在要求中新增標頭。本範例中的 VerifyAPIKey 變數是由 VerifyAPIKey 政策產生:
<HTTPModifier name="HM-add-headers-1">
<Add>
<Headers>
<Header name="partner-id">{verifyapikey.VAK-1.developer.app.partner-id}</Header>
</Headers>
</Add>
<AssignTo>request</AssignTo>
</HTTPModifier>2:修改回覆
以下範例會修改現有的回應物件,並在其中新增標頭:
<HTTPModifier name="HM-modify-response">
<Set>
<Headers>
<Header name="Cache-Hit">{lookupcache.LookupCache-1.cachehit}</Header>
</Headers>
</Set>
<IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables>
<AssignTo>response</AssignTo>
</HTTPModifier>這個範例不會建立新訊息。而是透過新增 HTTP 標頭來修改現有回應訊息。
由於這個範例在 <AssignTo> 元素中將 response 指定為變數名稱,因此這項政策會修改原始設定的回應物件,該物件含有目標伺服器傳回的資料。
這項政策新增至回應訊息的 HTTP 標頭,是衍生自 LookupCache 政策填入的變數。因此,由這項 HTTPModifier 政策修改的回應訊息會包含 HTTP 標頭,指出結果是否從快取中提取。在回應中設定標頭,有助於偵錯和排解問題。
3:移除查詢參數
以下範例會從要求中移除 apikey 查詢參數:
<HTTPModifier name="HM-remove-query-param">
<Remove>
<QueryParams>
<QueryParam name="apikey"/>
</QueryParams>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>使用 VerifyAPIKey 政策進行使用者驗證時,最佳做法是從要求訊息中移除 apikey 查詢參數。這麼做是為了避免將機密金鑰資訊傳遞至後端目標。
子元素參照
本節說明 <HTTPModifier> 的子元素。
<Add>
將資訊新增至要求或回應,由 <AssignTo> 元素指定。
<Add> 元素會在郵件中新增原始郵件沒有的屬性。請注意,<Set> 也提供這項功能。如要變更現有屬性的值,請使用 <Set> 元素。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | 複雜型別 |
| 父項元素 |
<HTTPModifier>
|
| 子元素 |
<FormParams><Headers><QueryParams> |
<Add> 元素使用下列語法:
語法
<HTTPModifier
continueOnError="[false|true]"
enabled="[true|false]"
name="POLICY_NAME" >
<Add>
<FormParams>
<FormParam name="FORMPARAM_NAME">FORMPARAM_VALUE</FormParam>
...
</FormParams>
<Headers>
<Header name="HEADER_NAME">HEADER_VALUE</Header>
...
</Headers>
<QueryParams>
<QueryParam name="QUERYPARAM_NAME">QUERYPARAM_VALUE</QueryParam>
...
</QueryParams>
</Add>
</HTTPModifier>範例 1
下列範例使用 <FormParams> 元素,從初始要求取得三個查詢字串參數的值,並將這些值設為目標端點要求的表單參數:
<HTTPModifier name="HM-add-formparams-3">
<Add>
<FormParams>
<FormParam name="username">{request.queryparam.name}</FormParam>
<FormParam name="zip_code">{request.queryparam.zipCode}</FormParam>
<FormParam name="default_language">{request.queryparam.lang}</FormParam>
</FormParams>
</Add>
<Remove>
<QueryParams/>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>範例 2
以下範例使用 <Headers> 元素,將 partner-id 標頭新增至傳送至目標端點的要求:
<HTTPModifier name="HM-add-headers-1">
<Add>
<Headers>
<Header name="partner-id">{verifyapikey.VAK-1.developer.app.partner-id}</Header>
</Headers>
</Add>
<AssignTo>request</AssignTo>
</HTTPModifier>範例 3
以下範例使用 <QueryParams> 元素,在要求中新增具有靜態值的單一查詢參數:
<HTTPModifier name="HM-add-queryparams-1">
<Add>
<QueryParams>
<QueryParam name="myParam">42</QueryParam>
</QueryParams>
</Add>
<AssignTo>request</AssignTo>
</HTTPModifier>本範例在要求前置流程中使用 <Add>。如果您在偵錯工具等工具中查看結果,對 https://example-target.com/get 的要求會變成 https://example-target.com/get?myParam=42。
<Add> 的子項元素支援動態字串替換,也就是訊息範本。
<FormParams> (<Add> 的子項)
在要求訊息中新增表單參數。這個元素對回覆訊息沒有影響。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | <FormParam> 元素陣列 |
| 父項元素 |
<Add>
|
| 子元素 |
<FormParam> |
<FormParams> 元素使用下列語法:
語法
<HTTPModifier continueOnError="[false|true]" enabled="[true|false]" name="POLICY_NAME" > <Add> <FormParams> <FormParam name="FORMPARAM_NAME">FORMPARAM_VALUE</FormParam> ... </FormParams> <AssignTo createNew="[true|false]" transport="http" type="[request|response]">DESTINATION_VARIABLE_NAME</AssignTo> </Add> </HTTPModifier>
範例 1
以下範例會在要求中新增單一表單參數 (answer) 和靜態值 (42):
<HTTPModifier name="HM-add-formparams-1">
<Add>
<FormParams>
<FormParam name="answer">42</FormParam>
</FormParams>
</Add>
<AssignTo>request</AssignTo>
</HTTPModifier>範例 2
以下範例會取得 name 查詢參數的值,並將其做為表單參數新增至要求,然後移除查詢參數:
<HTTPModifier name="HM-Swap-QueryParam-to-FormParams">
<Add>
<FormParam name="name">{request.queryparam.name}
</Add>
<Remove>
<QueryParam name="name"/>
</Remove>
</HTTPModifier>請注意,這個範例並未指定 <AssignTo> 的目標。這項政策只會在要求中加入參數。
範例 3
以下範例會在要求中新增多個表單參數:
<HTTPModifier name="HM-add-formparams-3">
<Add>
<FormParams>
<FormParam name="username">{request.queryparam.name}</FormParam>
<FormParam name="zip_code">{request.queryparam.zipCode}</FormParam>
<FormParam name="default_language">{request.queryparam.lang}</FormParam>
</FormParams>
</Add>
<Remove>
<QueryParams/>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>這個範例會從原始要求取得查詢字串參數,並以不同名稱將這些參數新增為表單參數。然後移除原始查詢參數。 Apigee 會將修改過的要求傳送至目標端點。
您可以使用偵錯工具查看流程。您會發現要求主體包含網址編碼的表單資料,這些資料原本是以查詢字串參數的形式傳遞:
username=nick&zip_code=90210&default_language=en
只有在符合下列條件時,才能使用 <FormParams>:
- HTTP 動詞:
GET、POST - 訊息類型:要求
- 下列其中一項 (或兩項):
- 表單資料:設為某個值或
""(空字串)。舉例來說,使用curl時,請在要求中加入-d ""。 Content-Length標頭:設為 0 (如果原始要求中沒有資料;否則為目前的長度,以位元組為單位)。舉例來說,您可以在要求中加入curl,然後新增-H "Content-Length: 0"。
- 表單資料:設為某個值或
例如:
curl -vL -X POST -d "" -H "Content-Type: application/x-www-form-urlencoded" https://ahamilton-eval-test.apigee.net/am-test
新增 <FormParams> 後,Apigee 會將要求的 Content-Type 標頭設為 application/x-www-form-urlencoded,然後再將訊息傳送至目標服務。
<Headers> (<Add> 的子項)
將新標頭新增至指定的要求或回應,由 <AssignTo> 元素指定。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | <Header> 元素陣列 |
| 父項元素 |
<Add>
|
| 子元素 |
<Header> |
<Headers> 元素使用下列語法:
語法
<HTTPModifier
continueOnError="[false|true]"
enabled="[true|false]"
name="POLICY_NAME" >
<Add>
<Headers>
<Header name="HEADER_NAME">HEADER_VALUE</Header>
...
</Headers>
</Add>
</HTTPModifier>範例 1
以下範例會在要求訊息中新增 partner-id 標頭,並將 verifyapikey.VAK-1.developer.app.partner-id 流程變數的值指派給該標頭。
<HTTPModifier name="HM-add-headers-1">
<Add>
<Headers>
<Header name="partner-id">{verifyapikey.VAK-1.developer.app.partner-id}</Header>
</Headers>
</Add>
<AssignTo>request</AssignTo>
</HTTPModifier><QueryParams> (<Add> 的子項)
在要求中新增查詢參數。這個元素不會對回應造成任何影響。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | <QueryParam> 元素陣列 |
| 父項元素 |
<Add>
|
| 子元素 |
<QueryParam> |
<QueryParams> 元素使用下列語法:
語法
<HTTPModifier
continueOnError="[false|true]"
enabled="[true|false]"
name="POLICY_NAME" >
<Add>
<QueryParams>
<QueryParam name="QUERYPARAM_NAME">QUERYPARAM_VALUE</QueryParam>
...
</QueryParams>
</Add>
</HTTPModifier>範例 1
以下範例會在要求中新增查詢參數 myParam,並將值 42 指派給該參數:
<HTTPModifier name="HM-add-queryparams-1">
<Add>
<QueryParams>
<QueryParam name="myParam">42</QueryParam>
</QueryParams>
</Add>
<AssignTo>request</AssignTo>
</HTTPModifier>只有在符合下列條件時,才能使用 <QueryParams>:
- HTTP 動詞:
GET、POST - 訊息類型:要求
此外,只有在 <AssignTo> 元素的 type 屬性為要求訊息時,才能設定查詢參數。在回應中設定這些標頭不會產生任何影響。
如果在政策中定義空白的查詢參數陣列 (<Add><QueryParams/></Add>),政策就不會新增任何查詢參數。這與省略 <QueryParams> 的效果相同。
<AssignTo>
決定 HTTPModifier 政策要處理的物件。選項如下:
請注意,在某些情況下,您無法變更 HTTPModifier 政策作用的物件。
舉例來說,您無法使用 <Add> 或 <Set> 在回應中新增或變更查詢參數 (<QueryParams>) 或表單參數 (<FormParams>)。您只能在要求中操控查詢參數和表單參數。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | 字串 |
| 父項元素 |
<HTTPModifier>
|
| 子元素 | 無 |
如未指定 <AssignTo>,或指定 <AssignTo> 元素但未指定該元素的文字值,政策會根據政策的執行位置,對預設要求或回應採取行動。如果政策在要求流程中執行,就會影響要求訊息。如果政策在回應流程中執行,預設會影響回應。
<AssignTo> 元素使用下列語法:
語法
<HTTPModifier continueOnError="[false|true]" enabled="[true|false]" name="POLICY_NAME" > <AssignTo createNew="[true|false]" transport="http" type="[request|response]">DESTINATION_VARIABLE_NAME</AssignTo> </HTTPModifier>
範例 1
以下範例在 <AssignTo> 的文字中未指定任何訊息。這表示政策會對 request 或 response 訊息採取行動,視政策的執行位置而定。
<HTTPModifier name="assignto-1"> <AssignTo createNew="false" transport="http" type="request"/>-- no-op --> ... </HTTPModifier>
如果您指定 createNew="false",但未明確提供訊息名稱,<AssignTo> 的其他屬性就無關緊要。在這種情況下,您可能希望完全省略 <AssignTo> 元素。
範例 2
以下範例會建立新的要求物件,覆寫現有物件:
<HTTPModifier name="assignto-2"> <AssignTo createNew="true" transport="http" type="request"/> ... </HTTPModifier>
建立新的要求或回應物件時,HTTPModifier 政策的其他元素 (例如 <Add> 和 <Set>) 會對該新要求物件採取行動。
您可以在流程中稍後存取其他政策中的新要求物件,也可以使用 ServiceCallout 政策將新要求物件傳送至外部服務。
範例 3
以下範例會建立名為 MyRequestObject 的新要求物件:
<HTTPModifier name="assignto-3"> <AssignTo createNew="true" transport="http" type="request">MyRequestObject</AssignTo> ... </HTTPModifier>
建立新的要求或回應物件時,HTTPModifier 政策的其他元素 (例如 <Add> 和 <Set>) 會對該新要求物件採取行動。
您可以在流程中稍後的其他政策中,依名稱存取新的要求物件,也可以使用 ServiceCallout 政策,將新的要求物件傳送至外部服務。
下表說明 <AssignTo> 的屬性:
| 屬性 | 說明 | 是否必要 | 類型 |
|---|---|---|---|
createNew |
決定這項政策是否會在指派值時建立新訊息。 如果是 如果
如果未指定
|
選用 | 布林值 |
transport |
指定要求或回應訊息類型的傳輸類型。 預設值為 |
選用 | 字串 |
type |
當 createNew 為 true 時,指定新訊息的類型。有效值為 request 或 response。預設值為 |
選用 | 字串 |
<DisplayName>
除了 name 屬性之外,您也可以在管理 UI 代理程式編輯器中使用其他更自然的名稱標記政策。
<DisplayName> 元素適用於所有政策。
| 預設值 | 不適用 |
| 是否必要? | (非必要) 如果省略 <DisplayName>,系統會使用政策的 name 屬性值。 |
| 類型 | 字串 |
| 上層元素 | <PolicyElement> |
| 子元素 | 無 |
<DisplayName> 元素使用以下語法:
語法
<PolicyElement> <DisplayName>POLICY_DISPLAY_NAME</DisplayName> ... </PolicyElement>
範例
<PolicyElement> <DisplayName>My Validation Policy</DisplayName> </PolicyElement>
<DisplayName> 元素沒有屬性或子項元素。
<IgnoreUnresolvedVariables>
判斷遇到無法解析的變數時,是否要停止處理。
| 預設值 | 否 |
| 必填與否 | 選用 |
| 類型 | 布林值 |
| 父項元素 |
<HTTPModifier>
|
| 子元素 | 無 |
設為 true 可忽略未解析的變數並繼續處理;否則請設為 false。預設值為 false。
將 <IgnoreUnresolvedVariables> 設為 true 與將 <HTTPModifier> 的 continueOnError 設為 true 不同,因為前者專門用於設定及取得變數值。如果將 continueOnError 設為 true,Apigee 會忽略所有錯誤,而不只是使用變數時發生的錯誤。
<IgnoreUnresolvedVariables> 元素使用下列語法:
語法
<HTTPModifier
continueOnError="[false|true]"
enabled="[true|false]"
name="POLICY_NAME" >
<IgnoreUnresolvedVariables>[true|false]</IgnoreUnresolvedVariables>
</HTTPModifier>範例 1
以下範例會將 <IgnoreUnresolvedVariables> 設為 true:
<HTTPModifier name="HM-Set-Headers"> <Set> <Headers> <Header name='new-header'>{possibly-defined-variable}<Header> </Headers> </Set> <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables> </HTTPModifier>
由於 <IgnoreUnresolvedVariables> 設為 true,如果未定義 possibly-defined-variable 變數,這項政策就不會擲回錯誤。
<Remove>
從訊息中移除標頭、查詢參數或表單參數。空白標記會移除所有對應的參數,包括標頭、formparams 和 queryparams。
受影響的訊息可以是要求或回覆。您可以使用 <AssignTo> 元素,指定 <Remove> 要處理的訊息。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | 複雜型別 |
| 父項元素 |
<HTTPModifier>
|
| 子元素 |
<FormParams><Headers><QueryParams> |
<Remove> 的常見用途是從傳入的要求物件中刪除含有私密資訊的查詢參數或標頭,避免傳送至後端伺服器。
<Remove> 元素使用下列語法:
語法
<HTTPModifier continueOnError="[false|true]" enabled="[true|false]" name="POLICY_NAME" > <!-- Can also be empty to remove everything from the message (<Remove/>) --> <Remove> <!-- Can also be an empty array to remove all FormParams (<FormParams/>) --> <FormParams> <FormParam name="FORMPARAM_NAME">FORMPARAM_VALUE</FormParam> ... </FormParams> <!-- Can also be an empty array to remove all Headers (<Headers/>) --> <Headers> <Header name="HEADER_NAME">HEADER_VALUE</Header> ... </Headers> <!-- Can also be an empty array to remove all QueryParams (<QueryParams/>) --> <QueryParams> <QueryParam name="QUERYPARAM_NAME">QUERYPARAM_VALUE</QueryParam> ... </QueryParams> </Remove> </HTTPModifier>
範例 1
以下範例會從 request 物件中移除所有表單參數和查詢參數:
<HTTPModifier name="HM-remove-2">
<Remove>
<!-- Empty (<FormParams/>) removes all form parameters -->
<FormParams/>
<QueryParams>
<QueryParam name="qp1"/>
</QueryParams>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>範例 2
以下範例會從訊息物件中移除所有內容:
<HTTPModifier name="HM-remove-3"> <Remove/> <AssignTo>request</AssignTo> </HTTPModifier>
通常只有在您要使用 <Set> 元素將某些替代值設定到訊息中時,才會執行這項操作。
<FormParams> (<Remove> 的子項)
從要求中移除指定的表單參數。這個元素不會對回應造成任何影響。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | <FormParam> 元素陣列或空陣列 |
| 父項元素 |
<Remove>
|
| 子元素 |
<FormParam> |
<FormParams> 元素使用下列語法:
語法
<HTTPModifier continueOnError="[false|true]" enabled="[true|false]" name="POLICY_NAME" > <!-- Can also be empty to remove everything from the message (<Remove/>) --> <Remove> <!-- Can also be an empty array to remove all FormParams (<FormParams/>) --> <FormParams> <FormParam name="FORMPARAM_NAME">FORMPARAM_VALUE</FormParam> ... </FormParams> </Remove> </HTTPModifier>
範例 1
以下範例會從要求中移除三個表單參數:
<HTTPModifier name="HM-remove-formparams-1">
<Remove>
<FormParams>
<FormParam name="form_param_1"/>
<FormParam name="form_param_2"/>
<FormParam name="form_param_3"/>
</FormParams>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>範例 2
以下範例會從要求中移除所有表單參數:
<HTTPModifier name="HM-remove-formparams-2">
<Remove>
<FormParams/>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>範例 3
如果有多個表單參數的名稱相同,請使用下列語法:
<HTTPModifier name="HM-remove-formparams-3">
<Remove>
<FormParams>
<FormParam name="f1"/>
<FormParam name="f2"/>
<FormParam name="f3.2"/>
</FormParams>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>這個範例會移除 f1、f2 和 f3 的第二個值。如果 f3 只有一個值,則不會移除。
只有在符合下列條件時,才能使用 <FormParams>:
- 訊息類型:要求
Content-Type:application/x-www-form-urlencoded
<Headers> (<Remove> 的子項)
從要求或回應中移除指定 HTTP 標頭,由 <AssignTo> 元素指定。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | <Header> 元素陣列或空陣列 |
| 父項元素 |
<Remove>
|
| 子元素 |
<Header> |
<Headers> 元素使用下列語法:
語法
<HTTPModifier continueOnError="[false|true]" enabled="[true|false]" name="POLICY_NAME" > <!-- Can also be empty to remove everything from the message (<Remove/>) --> <Remove> <!-- Can also be an empty array to remove all Headers (<Headers/>) --> <Headers> <Header name="HEADER_NAME">HEADER_VALUE</Header> ... </Headers> </Remove> </HTTPModifier>
範例 1
以下範例會從要求中移除 user-agent 標頭:
<HTTPModifier name="HM-remove-one-header">
<Remove>
<Headers>
<Header name="user-agent"/>
</Headers>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>範例 2
以下範例會從要求中移除所有標頭:
<HTTPModifier name="HM-remove-all-headers">
<Remove>
<Headers/>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>範例 3
如果有多個名稱相同的標頭,請使用下列語法:
<HTTPModifier name="HM-remove-headers-3">
<Remove>
<Headers>
<Header name="h1"/>
<Header name="h2"/>
<Header name="h3.2"/>
</Headers>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>這個範例會從要求中移除 h1、h2 和 h3 的第二個值。如果 h3 只有一個值,則不會移除。
<QueryParams> (<Remove> 的子項)
從要求中移除指定的查詢參數。這個元素不會對回應造成任何影響。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | <QueryParam> 元素陣列或空陣列 |
| 父項元素 |
<Remove>
|
| 子元素 |
<QueryParam> |
<QueryParams> 元素使用下列語法:
語法
<HTTPModifier continueOnError="[false|true]" enabled="[true|false]" name="POLICY_NAME" > <!-- Can also be empty to remove everything from the message (<Remove/>) --> <Remove> <!-- Can also be an empty array to remove all QueryParams (<QueryParams/>) --> <QueryParams> <QueryParam name="QUERYPARAM_NAME">QUERYPARAM_VALUE</QueryParam> ... </QueryParams> </Remove> </HTTPModifier>
範例 1
以下範例會從要求中移除單一查詢參數:
<HTTPModifier name="HM-remove-queryparams-1">
<Remove>
<QueryParams>
<QueryParam name="qp1"/>
</QueryParams>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>範例 2
以下範例會從要求中移除所有查詢參數:
<HTTPModifier name="HM-remove-queryparams-2">
&tl;Remove>
<QueryParams/>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>範例 3
如果有多個同名查詢參數,請使用下列語法:
<HTTPModifier name="HM-remove-queryparams-3">
<Remove>
<QueryParams>
<QueryParam name="qp1"/>
<QueryParam name="qp2"/>
<QueryParam name="qp3.2"/>
</QueryParams>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>這個範例會從要求中移除 qp1、qp2 和 qp3 的第二個值。如果 qp3 只有一個值,則不會移除。
範例 4
以下範例會從要求中移除 apikey 查詢參數:
<HTTPModifier name="HM-remove-query-param">
<Remove>
<QueryParams>
<QueryParam name="apikey"/>
</QueryParams>
</Remove>
<AssignTo>request</AssignTo>
</HTTPModifier>只有在符合下列條件時,才能使用 <QueryParams>:
- HTTP 動詞:
GET、POST - 訊息類型:要求
<Set>
在要求或回應訊息中設定資訊,由 <AssignTo> 元素指定。<Set> 會覆寫原始郵件中已有的標頭、查詢或表單參數,或新增原始郵件中沒有的參數。
HTTP 訊息中的標頭、查詢和表單參數可能包含多個值。如要為標頭或參數新增其他值,請改用 <Add> 元素。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | 複雜型別 |
| 父項元素 |
<HTTPModifier>
|
| 子元素 |
<FormParams><Headers><Path><QueryParams><StatusCode><Verb><Version> |
<Set> 元素使用下列語法:
語法
<HTTPModifier continueOnError="[false|true]" enabled="[true|false]" name="POLICY_NAME" > <Set> <FormParams> <FormParam name="FORMPARAM_NAME">FORMPARAM_VALUE</FormParam> ... </FormParams> <Headers> <Header name="HEADER_NAME">HEADER_VALUE</Header> ... </Headers> <Path>PATH</Path> <QueryParams> <QueryParam name="QUERYPARAM_NAME">QUERYPARAM_VALUE</QueryParam> ... </QueryParams> <StatusCode>HTTP_STATUS_CODE or {variable}</StatusCode> <Verb>[GET|POST|PUT|PATCH|DELETE|{variable}]</Verb> <Version>[1.0|1.1|{variable}]</Verb> </Set> </HTTPModifier>
範例
以下範例會設定特定標頭。在要求流程中附加這項政策後,上游系統就能接收原始傳入要求中未包含的其他標頭。
<HTTPModifier name="HM-Set-Header">
<Set>
<Headers>
<Header name="authenticated-developer">{verifyapikey.VAK-1.developer.id}</Header>
</Headers>
</Set>
<AssignTo>request</AssignTo>
</HTTPModifier><FormParams> (<Set> 的子項)
覆寫要求中現有的表單參數,並以您透過這個元素指定的新值取代。這個元素不會對回應造成任何影響。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | <FormParam> 元素陣列 |
| 父項元素 |
<Set>
|
| 子元素 |
<FormParam> |
<FormParams> 元素使用下列語法:
語法
<HTTPModifier
continueOnError="[false|true]"
enabled="[true|false]"
name="POLICY_NAME" >
<Set>
<FormParams>
<FormParam name="FORMPARAM_NAME">FORMPARAM_VALUE</FormParam>
...
</FormParams>
</Set>
</HTTPModifier>範例 1
在下列範例中,系統會在新的自訂要求中,將名為 myparam 的表單參數設為 request.header.myparam 變數的值:
<HTTPModifier name="HM-set-formparams-1"> <Set> <FormParams> <FormParam name="myparam">{request.header.myparam}</FormParam> </FormParams> </Set> <AssignTo createNew="true" transport="http" type="request>>MyCustomRequest</AssignTo> </HTTPModifier>
只有在符合下列條件時,才能使用 <FormParams>:
- HTTP 動詞:
POST - 訊息類型:要求
如果您在政策中定義空白表單參數 (<Add><FormParams/></Add>),政策不會新增任何表單參數。這與省略 <FormParams> 相同。
<Set> 會將訊息的 Content-Type 變更為 application/x-www-form-urlencoded,然後傳送至目標端點。
<Headers> (<Set> 的子項)
覆寫要求或回應中現有的 HTTP 標頭,由 <AssignTo> 元素指定。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | <Header> 元素陣列 |
| 父項元素 |
<Set>
|
| 子元素 |
<Header> |
<Headers> 元素使用下列語法:
語法
<HTTPModifier
continueOnError="[false|true]"
enabled="[true|false]"
name="POLICY_NAME" >
<Set>
<Headers>
<Header name="HEADER_NAME">HEADER_VALUE</Header>
...
</Headers>
</Set>
</HTTPModifier>範例 1
以下範例會將 x-ratelimit-remaining 標頭設為 ratelimit.Quota-1.available.count 變數的值:
<HTTPModifier name="HM-Set-RateLimit-Header">
<Set>
<Headers>
<Header name="X-RateLimit-Remaining">{ratelimit.Quota-1.available.count}</Header>
</Headers>
</Set>
<AssignTo>response</AssignTo>
</HTTPModifier>如果在政策中定義空白標頭 (<Set><Headers/></Set>),政策就不會設定任何標頭。這與省略 <Headers> 的效果相同。
<Path> (<Set> 的子項)
<QueryParams> (<Set> 的子項)
以新值覆寫要求中現有的查詢參數。這個元素不會對回應造成任何影響。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | <QueryParam> 元素陣列 |
| 父項元素 |
<Set>
|
| 子元素 |
<QueryParam> |
<QueryParams> 元素使用下列語法:
語法
<HTTPModifier
continueOnError="[false|true]"
enabled="[true|false]"
name="POLICY_NAME" >
<Set>
<QueryParams>
<QueryParam name="QUERYPARAM_NAME">QUERYPARAM_VALUE</QueryParam>
...
</QueryParams>
</Set>
</HTTPModifier>範例 1
以下範例會將 address 查詢參數設為 request.header.address 變數的值:
<HTTPModifier name="HM-set-queryparams-1"> <Set> <QueryParams> <QueryParam name="address">{request.header.address}</QueryParam> </QueryParams> </Set> </HTTPModifier>
只有在符合下列條件時,才能使用 <QueryParams>:
- HTTP 動詞:
GET、POST - 訊息類型:要求
如果在政策中定義空白查詢參數 (<Set><QueryParams/></Set>),政策就不會設定任何查詢參數。這與省略 <QueryParams> 的效果相同。
<StatusCode> (<Set> 的子項)
設定回應的狀態碼。這個元素不會對要求造成任何影響。
| 預設值 | 「200」(當 <AssignTo> 的 createNew 屬性設為「true」時) |
| 必填與否 | 選用 |
| 類型 | 字串或 VARIABLE |
| 父項元素 |
<Set>
|
| 子元素 | 無 |
<StatusCode> 元素使用下列語法:
語法
<HTTPModifier continueOnError="[false|true]" enabled="[true|false]" name="POLICY_NAME" > <Set> <StatusCode>HTTP_STATUS_CODE or {variable}</StatusCode> </Set> </HTTPModifier>
範例 1
以下範例會設定簡單的狀態碼:
<HTTPModifier name="HM-set-statuscode-404">
<Set>
<StatusCode>404<<StatusCode>
</Set>
<AssignTo>response</AssignTo>
</HTTPModifier>範例 2
系統會將 <StatusCode> 的內容視為訊息範本。也就是說,系統會在執行階段將大括號括住的變數名稱,替換為參照變數的值,如下例所示:
<HTTPModifier name="set-statuscode-2">
<Set>
<StatusCode>{calloutresponse.status.code}</StatusCode>
</Set>
<AssignTo>response</AssignTo>
</HTTPModifier>只有在符合下列條件時,才能使用 <StatusCode>:
- 訊息類型:回覆
<Verb> (<Set> 的子項)
在要求中設定 HTTP 動詞。這個元素不會對回應造成任何影響。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | 字串或 VARIABLE |
| 父項元素 |
<Set>
|
| 子元素 | 無 |
<Verb> 元素使用下列語法:
語法
<HTTPModifier continueOnError="[false|true]" enabled="[true|false]" name="POLICY_NAME" > <Set> <Verb>[GET|POST|PUT|PATCH|DELETE|{variable}]</Verb> </Set> </HTTPModifier>
範例 1
以下範例會在要求中設定簡單的動詞:
<HTTPModifier name="HM-set-verb-1">
<Set>
<Verb>POST</Verb>
</Set>
<AssignTo>request</AssignTo>
</HTTPModifier>範例 2
系統會將 <Verb> 的內容視為訊息範本。也就是說,系統會在執行階段將以大括號括住的變數名稱,替換為參照變數的值。
以下範例使用變數填入動詞:
<HTTPModifier name="HM-set-verb-to-dynamic-value"> <Set> <Verb>{my_variable}</Verb> </Set> <AssignTo>request</AssignTo> </HTTPModifier>
只有在符合下列條件時,才能使用 <Verb>:
- 訊息類型:要求
<Version> (<Set> 的子項)
設定要求中的 HTTP 版本。這個元素不會對回應造成任何影響。
| 預設值 | 不適用 |
| 必填與否 | 選用 |
| 類型 | 字串或 VARIABLE |
| 父項元素 |
<Set>
|
| 子元素 | 無 |
<Version> 元素使用下列語法:
語法
<HTTPModifier continueOnError="[false|true]" enabled="[true|false]" name="POLICY_NAME" > <Set> <Version>[1.0|1.1|{variable}]</Verb> </Set> </HTTPModifier>
範例 1
以下範例會將版本號碼設為 1.1:
<HTTPModifier name="HM-set-version-1">
<Set>
<Version>1.1</Version>
</Set>
</HTTPModifier>範例 2
以下範例使用大括號中的變數設定版本號碼:
<HTTPModifier name="HM-set-version-2">
<Set>
<Version>{my_version}</Version>
</Set>
<AssignTo>request</AssignTo>
</HTTPModifier>系統會將 <Version> 的內容視為訊息範本。也就是說,系統會在執行階段將以大括號括住的變數名稱,替換為所參照變數的值。
只有在符合下列條件時,才能使用 <Version>:
- 訊息類型:要求
建立自訂要求訊息
您可以使用 HTTPModifier 建立自訂要求訊息。建立自訂要求後,您可以透過下列方式使用:
- 在其他政策中存取變數
- 將其傳遞至外部服務
如要建立自訂要求訊息,請在 HTTPModifier
政策中使用 <AssignTo> 元素。將 createNew 設為 true,並在元素主體中指定新訊息的名稱,如下列範例所示:
<HTTPModifier name="assignto-3"> <AssignTo createNew="true" transport="http" type="request">MyRequestObject</AssignTo> ... </HTTPModifier>
根據預設,Apigee 不會對自訂要求訊息執行任何操作。建立後,Apigee 會繼續使用原始要求完成流程。如要使用自訂要求,請新增政策,使用要求訊息,並在該政策的設定中明確參照新建立的要求訊息。這樣一來,您就能將自訂要求傳遞至外部服務端點。
下列範例會建立自訂要求訊息:
範例 1
以下範例會使用 HTTPModifier 建立自訂要求物件:
<HTTPModifier name="HTTPModifier-3"> <AssignTo createNew="true" type="request">MyCustomRequest</AssignTo> <Set> <QueryParams> <QueryParam name="address">{request.queryparam.addy}</QueryParam> </QueryParams> <Verb>GET</Verb> </Set> <IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables> </HTTPModifier>
這個範例:
- 建立名為
MyCustomRequest的新要求訊息物件。 - 在 MyCustomRequest 中,這項政策:
- 將自訂訊息的
address查詢參數設為傳入要求addy查詢參數的值。 - 將 HTTP 動詞設為
GET。
- 將自訂訊息的
- 將
<IgnoreUnresolvedVariables>設為false。當<IgnoreUnresolvedVariables>為false時,如果政策設定中參照的其中一個變數不存在,Apigee 會在 API 流程中進入錯誤狀態。
範例 2
以下是另一個範例,說明如何使用 HTTPModifier 建立自訂要求物件:
<HTTPModifier name="HTTPModifier-2"> <AssignTo createNew="true" type="request">partner.request</AssignTo> <Set> <Verb>POST</Verb> </Set> </HTTPModifier>
這個範例會建立名為 partner.request 的新自訂要求。然後在新要求中設定 <Verb>。
您可以在流程中稍後發生的另一個 HTTPModifier 政策中,存取自訂訊息的各種屬性。以下範例會從具名的自訂回應中取得標頭的值,並將其放入要求訊息的新標頭中:
<HTTPModifier name="HM-Set-Header">
<AssignTo>request</AssignTo>
<Set>
<Headers>
<Header name="injected-approval-id">{MyCalloutResponse.header.approval-id}</Header>
</Headers>
</Set>
</HTTPModifier>錯誤代碼
本節說明這項政策觸發錯誤時,Apigee 傳回的錯誤代碼和錯誤訊息,以及 Apigee 設定的錯誤變數。如果您要開發錯誤處理規則,就必須瞭解這項資訊。如需更多資訊,請參閱「關於政策錯誤的相關資訊」和「處理錯誤」。
執行階段錯誤
政策執行時可能會發生這些錯誤。
| 錯誤代碼 | HTTP 狀態 | 原因 | 修正 |
|---|---|---|---|
entities.UnresolvedVariable |
500 |
訊息範本變數未定義或超出範圍。 | |
steps.httpmodifier.InvalidStatusCode |
500 |
狀態碼的解析值無效。如需更多資訊,請參閱錯誤字串。 | build |
部署錯誤
部署含有這項政策的 Proxy 時,可能會發生這些錯誤。
| 錯誤名稱 | 原因 | 修正 |
|---|---|---|
InvalidIndex |
如果 HTTPModifier 政策的 <Remove> 元素中指定的索引為 0 或負數,則 API Proxy 的部署作業會失敗。 |
build |
錯誤變數
當這項政策在執行階段觸發錯誤時,系統就會設定這些變數。詳情請參閱「關於政策錯誤的相關資訊」。
| 變數 | 地點 | 範例 |
|---|---|---|
httpmodifier.POLICY_NAME.failed |
POLICY_NAME 是擲回錯誤的政策的使用者指定名稱。 | httpmodifier.HM-SetResponse.failed = true |
錯誤回應範例
{
"fault":{
"detail":{
"errorcode":"steps.httpmodifier.InvalidStatusCode"
},
"faultstring":"HTTPModifier[HM-SetResponse]: Invalid status code bad_request"
}
}錯誤規則範例
<FaultRule name="HTTPModifier Faults">
<Step>
<Name>HM-CustomNonMessageTypeErrorResponse</Name>
<Condition>(fault.name Matches "InvalidStatusCode")</Condition>
</Step>
<Condition>(httpmodifier.failed = true)</Condition>
</FaultRule>結構定義
每個政策類型都由 XML 架構 (.xsd) 定義。如需參考,請前往 GitHub 查看政策架構。