Anda sedang melihat dokumentasi Apigee dan Apigee hybrid.
Lihat dokumentasi
Apigee Edge.
UnresolvedVariable
Kode error
steps.assignmessage.UnresolvedVariable
Isi respons error
{ "fault": { "faultstring": "AssignMessage[policy_name]: unable to resolve variable [variable_name]", "detail": { "errorcode": "steps.assignmessage.UnresolvedVariable" } } }
Penyebab
Error ini terjadi jika variabel yang ditentukan dalam kebijakan Tetapkan Pesan adalah:
- di luar cakupan (tidak tersedia dalam alur tertentu tempat kebijakan dijalankan) atau
- tidak dapat diselesaikan (tidak ditentukan)
Misalnya, error ini terjadi jika kebijakan Tetapkan Pesan dijalankan dalam alur permintaan, tetapi atribut source
di elemen <Copy>
ditetapkan ke variabel response
atau error
atau variabel kustom lainnya yang tidak ada dalam alur permintaan.
Diagnosis
Identifikasi Kebijakan Tetapkan Pesan tempat error terjadi dan nama variabel yang tidak tersedia. Anda dapat menemukan kedua item ini di elemen
faultstring
respons error.Misalnya, dalam
faultstring
berikut, nama kebijakan adalahgoogleBook
dan variabelnya adalahvar
:"faultstring": "AssignMessage[googleBook]: unable to resolve variable var"
Dalam XML Kebijakan Pesan Penetapan yang gagal, pastikan nama variabel yang digunakan cocok dengan nama variabel yang diidentifikasi dalam string error (langkah #1 di atas). Misalnya, kebijakan berikut menetapkan atribut sumber di elemen
<Copy>
ke variabel bernamavar
, yang cocok dengan yang ada difaultstring
:<AssignMessage async="false" continueOnError="false" enabled="true" name="Assign-Message-1"> <DisplayName>googleBook</DisplayName> <Properties /> <Copy source="var"> <Headers> <Header name="user-agent" /> </Headers> </Copy> <IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables> <AssignTo createNew="true" transport="http" type="request">googleBookReq</AssignTo> </AssignMessage>
Tentukan apakah variabel ditentukan dan tersedia dalam alur tempat kebijakan Tetapkan Pesan dijalankan.
Jika variabel adalah:
- di luar cakupan (tidak tersedia dalam alur tertentu tempat kebijakan dijalankan) atau
- tidak dapat diselesaikan (tidak ditentukan)
maka itulah penyebab error.
Sebagai contoh, misalkan kebijakan Tetapkan Pesan yang ditampilkan di atas dijalankan dalam alur permintaan. Periksa apakah variabel
var
ditentukan dalam kebijakan apa pun yang dieksekusi sebelum kebijakan Tetapkan Pesan dalam alur permintaan. Jika variabel belum ditentukan, Anda akan menerima kode error:steps.assignmessage.UnresolvedVariable
Resolusi
Pastikan variabel yang dirujuk dalam kebijakan ada dan tersedia dalam alur tertentu, tempat kebijakan Tetapkan Pesan sedang dijalankan.
Untuk memperbaiki contoh kebijakan yang ditampilkan di atas, Anda dapat mengubah atribut sumber di elemen <Copy>
menjadi variabel permintaan atau variabel kustom jenis pesan lainnya yang ada dalam alur permintaan.
<AssignMessage async="false" continueOnError="false" enabled="true" name="Assign-Message-1">
<DisplayName>googleBook</DisplayName>
<Properties />
<Copy source="request">
<Headers>
<Header name="user-agent" />
</Headers>
</Copy>
<IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables>
<AssignTo createNew="true" transport="http" type="request">googleBookReq</AssignTo>
</AssignMessage>
VariableOfNonMsgType
Kode error
steps.assignmessage.VariableOfNonMsgType
Isi respons error
{ "fault": { "faultstring": "AssignMessage[policy_name]: value of variable [variable] is not of type Message", "detail": { "errorcode": "steps.assignmessage.VariableOfNonMsgType" } } }
Penyebab
Error ini terjadi jika atribut source
di elemen <Copy>
ditetapkan ke variabel yang bukan dari jenis message.
Variabel jenis pesan mewakili seluruh permintaan dan respons HTTP. Variabel alur bawaan request
, response
, dan message
adalah jenis pesan. Untuk mempelajari variabel pesan lebih lanjut, lihat Referensi variabel.
Diagnosis
Identifikasi Kebijakan Tetapkan Pesan tempat error terjadi dan nama variabel yang jenisnya salah. Anda dapat menemukan kedua item ini di elemen
faultstring
respons error. Misalnya, dalamfaultstring
berikut, nama kebijakan adalahGenerateGeocodingRequest
dan variabelnya adalahPostalCode
:"faultstring": "AssignMessage[GenerateGeocodingRequest]: value of variable PostalCode is not of type Message"
Dalam XML Kebijakan Pesan Penetapan yang gagal, pastikan nama variabel yang ditetapkan di elemen
<Copy>
cocok dengan nama variabel yang diidentifikasi dalam string error (langkah #1 di atas). Misalnya, kebijakan berikut menetapkan atribut sumber ke variabel bernamaPostalCode
, yang cocok dengan yang ada difaultstring
:<AssignMessage name="GenerateGeocodingRequest"> <AssignTo createNew="true" type="request">GeocodingRequest</AssignTo> <AssignVariable> <Name>PostalCode</Name> <Ref>request.queryparam.postalcode</Ref> </AssignVariable> <AssignVariable> <Name>Country</Name> <Ref>request.queryparam.country</Ref> </AssignVariable> <Copy source="PostalCode"> <QueryParams> <QueryParam name="q" /> </QueryParams> </Copy> </AssignMessage>
Tentukan apakah variabel ini berjenis pesan atau bukan:
- Temukan kode dalam paket Proxy API, tempat variabel ditentukan terlebih dahulu.
- Setelah mengetahui kebijakan tempat variabel ditentukan dan diisi terlebih dahulu, Anda perlu menentukan jenis variabel tersebut sebagai berikut:
- Periksa nilai atribut type (jika ada).
- Jika atribut type tidak ada, variabel akan dianggap sebagai string.
- Jika jenis variabelnya bukan pesan (seperti string), hal itu adalah penyebab error. Anda dapat mempelajari variabel umum dan jenisnya di Referensi variabel.
Misalnya, lihat variabel PostalCode dalam XML di atas. Nilai variabel alur
request.queryparam.postalcode
ditetapkan di elemen<AssignVariable>
. Nilai ini adalah string, karena tidak ada atribut jenis yang ada dalam penetapan variabel.Sekarang, ingat bahwa variabel PostalCode digunakan dalam elemen
<Copy>
kebijakan Tetapkan Pesan:<Copy source="PostalCode"> <QueryParams> <QueryParam name="PostalCode" /> </QueryParams> </Copy>
Karena PostalCode bukan dari jenis pesan (string dalam contoh ini), Anda akan menerima kode error:
steps.assignmessage.VariableOfNonMsgType
Resolusi
Pastikan atribut source
di elemen <Copy>
dalam kebijakan Tetapkan Pesan yang gagal ditetapkan ke variabel alur jenis pesan yang ada.
Untuk memperbaiki kebijakan, Anda dapat mengubah atribut source
di elemen <Copy>
untuk menentukan variabel yang berjenis pesan. Misalnya, jika kebijakan Tetapkan Pesan seharusnya dijalankan dalam alur permintaan, Anda dapat menggunakan variabel jenis pesan request
atau variabel kustom jenis pesan lainnya.
<AssignMessage name="GenerateGeocodingRequest">
<AssignTo createNew="true" type="request">GeocodingRequest</AssignTo>
<AssignVariable>
<Name>PostalCode</Name>
<Ref>request.queryparam.postalcode</Ref>
</AssignVariable>
<AssignVariable>
<Name>Country</Name>
<Ref>request.queryparam.country</Ref>
</AssignVariable>
<Copy source="request">
<QueryParams>
<QueryParam name="PostalCode" />
</QueryParams>
</Copy>
</AssignMessage>