我已经在 Linux 机器上安装了 WSO2 EI 6.1.1。我为获取 GET 和 PUT 请求的休息接口创建了一个直通代理。我已经设置了一个 Java 类调解器,它应该根据请求的 url 中包含的参数做出一些决定:
http://xx.xx.xx.xx:8280/services/app/url?token=ABCD
当我向班级询问请求的上下文时,我可以看到信封的内容和请求。
System.out.println("Context: \n " + context.getMessageString());
To : /services/app/url?token=ABCD
MessageID : urn:uuid:431940fd-201e-43a3-aad1-0ca5e36297dd
Body : <?xml version='1.0' encoding='utf-8'?><soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"><soapenv:Body/></soapenv:Envelope>
如何获取 token 参数的值?我尝试过的任何方法都没有奏效。
更新:
这是当前的序列:
<?xml version="1.0" encoding="UTF-8"?>
<sequence name="jsonvalidate" xmlns="http://ws.apache.org/ns/synapse">
<log>
<property expression="get-property('query.param.token')" name="token"/>
</log>
<property name="pass" scope="default" type="STRING" value="yes"/>
<property expression="get-property('query.param.token')"
name="token" scope="default" type="STRING" xmlns:ns="http://org.apache.synapse/xsd"/>
<class name="authzMediator.validate">
<axis2ns15:property name="validated" value="1" xmlns:axis2ns15="http://ws.apache.org/ns/synapse"/>
<axis2ns16:property name="validated1" value="yes" xmlns:axis2ns16="http://ws.apache.org/ns/synapse"/>
</class>
<log category="DEBUG">
<property expression="get-property('token')" name="token1" xmlns:ns="http://org.apache.synapse/xsd"/>
</log>
<filter xmlns:ns="http://org.apache.synapse/xsd" xpath="get-property('pass') = 'yes'">
<then>
<class name="authzMediator.trace">
<axis2ns17:property name="msg" value="YES" xmlns:axis2ns17="http://ws.apache.org/ns/synapse"/>
</class>
</then>
<else>
<class name="authzMediator.trace">
<axis2ns18:property name="msg" value="NO" xmlns:axis2ns18="http://ws.apache.org/ns/synapse"/>
</class>
<drop/>
</else>
</filter>
</sequence>
我看到的是,在第一步(日志)中我看到了这个:
[EI-Core] INFO - LogMediator To: /services/lsrest/clients/jordipc/3/0/14?token=patata, MessageID: urn:uuid:3b08226e-4a46-474a-8d7c-c4c786e51b4c, Direction: request, token = null