基于HTTP协议的JSON-RPC 2.0服务端
需要在HTTP服务器上运行
关于JSON-RPC 2.0
创建JSON-RPC 2.0服务端
可选在构造参数中指定监听客户端调用的监听器对象
如果不指定参数,保用对象自身监听客户端调用
客户端可以调用的远程对象名或远程方法名字,
客户端传过来的params参数必须是数组
服务端会展开此数组作为函数的调用参数
函数第一个返回值指定为客户端获取的result返回值
函数的第二个返回值指定为客户端error错误对象
错误对象可以是数值,字符串、或符合JSON-RPC2.0协议的表对象,
指定自定义的aasdl
如果不指定,服务端会根据external自动生成aasdl
如果客户端请求的方法名为"?"时,返回此属性,
关于aasdl
webrpcjsonServerObject.rpc.afterJsonStringify = function(jsonData){
/*可以在这里加密服务端JSON,返回null中止本次调用*/
return jsonData;
}
webrpcjsonServerObject.rpc.beforeJsonParse = function(jsonData){
/*可以在这里解密客户端数据,返回null中止本次调用*/
return jsonData;
}
指定包含客户端可以调用的远程函数的表对象,可嵌套子表
如果远程函数名第一个字符是$,则第一个回调参数为$,$对象由run函数指定,
如果创建服务端对象的构造参数中没有指定表,
这个对象默认指向对象自身
可在调用run函数之前更改此对象
webrpcjsonServerObject.rpc.onError = function(err,requestData){
/*服务器内部错误时触发此事件
err为抛出的异常对象,一般为错误信息
requestData为客户端发送的请求数据*/
}
运行JSON-RPC服务端响应用户请求
可选在函数参数中所有名字首字符为$的回调函数的首个回调$参数,
$参数默认为request
_JSONRPC_INTERNAL_ERROR=-32603
_JSONRPC_INVALID_PARAMS=-32602
_JSONRPC_INVALID_REQUEST=-32600
_JSONRPC_METHOD_NOTFOUND=-32601
_JSONRPC_PARSE_ERROR=-32700