无法以 JSON 格式将参数传递给 REST API WSO2
Can not pass parameters to REST API WSO2 in JSON format
有人知道这个错误吗?
我将 json 传递给这样的请求:
{"param1":"hello world"}
属性 中介
action:set,
将动作设置为:表达式,
类型:字符串,
表达式:json-eval($.param1),
范围:axis2
似乎 API 无法提取“hello world”值,因为日志显示:
param1=null
与价值完美结合:
<property name="param1" value="HELLO WORLD" scope="default" type="STRING"/>
以这种方式为空:
<property name="param1" expression="json-eval($.param1)" scope="axis2" type="STRING"/>
API 源代码视图:
<api xmlns="http://ws.apache.org/ns/synapse" name="REST" context="/api/post">
<resource methods="POST" url-mapping="/createInvoice">
<inSequence>
<property name="operation" value="createInvoice" scope="default" type="STRING"/>
<log level="full" separator="|">
<property name="operation" expression="get-property('operation')"/>
<property name="step" value="request"/>
</log>
<property name="param1" expression="json-eval($.param1)" scope="axis2" type="STRING"/>
<property name="param2" expression="json-eval($.param2)" scope="default" type="STRING"/>
<log level="full" separator="|">
<property name="param1" expression="get-property('Axis2','param1')"/>
<property name="param2" expression="$ctx:param2"/>
</log>
<dbreport>
<connection>
<pool>
<dsName>OEBS_DS_MOS</dsName>
</pool>
</connection>
<statement>
<sql>call procedure.create_invoice(?,?)</sql>
<parameter expression="get-property('Axis2','param1')" type="VARCHAR"/>
<parameter expression="$ctx:param2" type="VARCHAR"/>
</statement>
</dbreport>
<payloadFactory media-type="json">
<format>{"response" : {"code" : "00", "message" : "success"}}</format>
<args/>
</payloadFactory>
<property name="RESPONSE" value="true" scope="default" type="STRING"/>
<property name="messageType" value="application/json" scope="axis2" type="STRING"/>
<property name="contentType" value="application/json" scope="axis2" type="STRING"/>
<respond/>
</inSequence>
<outSequence>
<payloadFactory media-type="json">
<format>{"response" : {"code" : "02", "message" : "outSeq"}}</format>
<args/>
</payloadFactory>
</outSequence>
<faultSequence>
<payloadFactory media-type="json">
<format>{"response" : {"code" : "01", "message" : "fail"}}</format>
<args/>
</payloadFactory>
</faultSequence>
</resource>
</api>
问题出在您的 属性 的 scope
上。
您在 scope="axis2"
中将值从 JSON 设置为 属性,因此您可以使用 get-property('axis2', 'param1')
或 $axis2:param1
.[=17 读取 属性 =]
或者您可以在默认范围内设置属性,现在您可以使用:get-property('param1')
,或$ctx:param1
。
这个documentation解释得很准确。
有人知道这个错误吗? 我将 json 传递给这样的请求:
{"param1":"hello world"}
属性 中介 action:set, 将动作设置为:表达式, 类型:字符串, 表达式:json-eval($.param1), 范围:axis2
似乎 API 无法提取“hello world”值,因为日志显示:
param1=null
与价值完美结合:
<property name="param1" value="HELLO WORLD" scope="default" type="STRING"/>
以这种方式为空:
<property name="param1" expression="json-eval($.param1)" scope="axis2" type="STRING"/>
API 源代码视图:
<api xmlns="http://ws.apache.org/ns/synapse" name="REST" context="/api/post">
<resource methods="POST" url-mapping="/createInvoice">
<inSequence>
<property name="operation" value="createInvoice" scope="default" type="STRING"/>
<log level="full" separator="|">
<property name="operation" expression="get-property('operation')"/>
<property name="step" value="request"/>
</log>
<property name="param1" expression="json-eval($.param1)" scope="axis2" type="STRING"/>
<property name="param2" expression="json-eval($.param2)" scope="default" type="STRING"/>
<log level="full" separator="|">
<property name="param1" expression="get-property('Axis2','param1')"/>
<property name="param2" expression="$ctx:param2"/>
</log>
<dbreport>
<connection>
<pool>
<dsName>OEBS_DS_MOS</dsName>
</pool>
</connection>
<statement>
<sql>call procedure.create_invoice(?,?)</sql>
<parameter expression="get-property('Axis2','param1')" type="VARCHAR"/>
<parameter expression="$ctx:param2" type="VARCHAR"/>
</statement>
</dbreport>
<payloadFactory media-type="json">
<format>{"response" : {"code" : "00", "message" : "success"}}</format>
<args/>
</payloadFactory>
<property name="RESPONSE" value="true" scope="default" type="STRING"/>
<property name="messageType" value="application/json" scope="axis2" type="STRING"/>
<property name="contentType" value="application/json" scope="axis2" type="STRING"/>
<respond/>
</inSequence>
<outSequence>
<payloadFactory media-type="json">
<format>{"response" : {"code" : "02", "message" : "outSeq"}}</format>
<args/>
</payloadFactory>
</outSequence>
<faultSequence>
<payloadFactory media-type="json">
<format>{"response" : {"code" : "01", "message" : "fail"}}</format>
<args/>
</payloadFactory>
</faultSequence>
</resource>
</api>
问题出在您的 属性 的 scope
上。
您在 scope="axis2"
中将值从 JSON 设置为 属性,因此您可以使用 get-property('axis2', 'param1')
或 $axis2:param1
.[=17 读取 属性 =]
或者您可以在默认范围内设置属性,现在您可以使用:get-property('param1')
,或$ctx:param1
。
这个documentation解释得很准确。