提问者:小点点

调用JSON-RPC方法通过URL使用jQuery


我需要参考一个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>

共1个答案

匿名用户

您最有可能寻找的部分是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服务在那里会更容易,但这取决于您。