我需要参考一个JSONRPC的方法由URL,并想知道如何做到这一点,如果你能做到这一点。
我想这样做,因为我想使用jQuery. deleder()在$.post中进行调用。看看这个例子,看看我想完成什么。我想用我的RPC方法替换“/echo/html/”。如果有必要,我可以将我的RPC重写为XAgent,但我宁愿先看看是否有人知道如何通过URL调用它。
我的RPC方法看起来像这样:openATMRPC. openATMFirst();它使用传统的javascript工作得很好,但是正如你所看到的,我希望它链接在jQuery延迟函数中,以便.始终运行。
var deferred = function(trueFalse) {
// return value from response as `deferred.promise`
// within `setTimeout` , after `1000` ms (one second)
return new $.Deferred(function (dfd) {
setTimeout(function () {
$.post("/echo/html/", {
html: trueFalse
})
// `deferred.always` utilized here ,
// to catch either `success` or `fail` ,
// not certain about `error` (`fail`) callbacks ?
.always(function (data) {
dfd.resolve(data)
})
}, 1000);
// return `deferred.promise()` ,
// e.g., "true" , or "false"
return dfd.promise()
})
};
更新
如果之前不清楚,很抱歉。这是远程调用的XSP代码。path Info属性是答案的一部分,但我还没有弄清楚如何使用它通过URL引用该方法,这就是我所寻求的。如果我引用“…/rpc”,我会收到一条“服务错误”消息,这是进度。如何在RPC中调用该方法-JSON通过URL是我的问题?
<xe:jsonRpcService id="jsonRpcService2" serviceName="openATMRPC" pathInfo="rpc">
<xe:this.methods>
<xe:remoteMethod name="openATMFirst">
<xe:this.script>
<![CDATA[print("into First");
var firstTry:boolean = atmBean.openATM(atmBean.atmID, userBean.userID, userBean.userPassword);
if(firstTry == false){
return firstTry.toString();
} else if(firstTry == true){
//atmBean.infoMessage = atmBean.atmID + " has been successfully Opened.";
return firstTry.toString();
}]]></xe:this.script></xe:remoteMethod>
您最有可能寻找的部分是JSONREST控件的确切地址。它们确实存在于XPage中(页面不需要做任何有用的事情)。查看示例服务:
<?xml version="1.0" encoding="UTF-8"?>
<xp:view xmlns:xp="http://www.ibm.com/xsp/core"
xmlns:xe="http://www.ibm.com/xsp/coreex">
<xe:jsonRpcService id="jsonRpcService1" serviceName="helloService">
<xe:this.methods>
<xe:remoteMethod name="sayHello">
<xe:this.arguments>
<xe:remoteMethodArg name="who" type="string"></xe:remoteMethodArg>
</xe:this.arguments>
<xe:this.script><![CDATA[return "Hello " + who;]]></xe:this.script>
</xe:remoteMethod>
</xe:this.methods>
</xe:jsonRpcService>
<xp:label value="Who" id="label1" for="inputText1"></xp:label>
<xp:inputText id="inputText1" value="#{viewScope.who}"></xp:inputText>
<xp:button value="Greet Me" id="button1">
<xp:eventHandler event="onclick" submit="false">
<xp:this.script><![CDATA[var deferred = helloService.sayHello(dojo.byId("#{id:inputText1}").value);
deferred.addCallback(function(result) {
alert(result)
});]]></xp:this.script>
</xp:eventHandler></xp:button>
</xp:view>
当然,这在幕后使用了Dojo。但是,当您查看服务URL-您可能正在寻找的内容时,您会发现如下内容:
/yournsf. nsf/sample.xsp?$$viewwid=!dwjn9ryrqh!
第一个值由浏览器在一个隐藏字段中发送,名称(不是id)$$eviwid,第二个是#{id: jsonRpcService1}
因此,您可以使用脚本块向下发送该值并获取您的endpoint。很可能REST服务在那里会更容易,但这取决于您。