JSON-RPC

本文介绍了JSON-RPC协议的基础知识,包括请求与响应的格式、错误处理机制、批量调用方式等,并通过具体示例展示了JSON-RPC的工作流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. JSON-RPC简介

JSON-RPC是一种基于JSON的跨语言远程调用协议。有文本传输数据小,便于调试扩展的特点。

2. 请求

JSON-RPC非常简单,在请求时向服务器传输数据格式如下(基于JSON2.0)

{ 
    "jsonrpc" : 2.0,
    "method" : "sayHello", 
    "params" : ["Hello JSON-RPC"], 
    "id" : 1
} 
  • jsonrpc:定义JSON-RPC版本。
  • method:调用的方法名。
  • params:方法传入的参数,若无参数则为null。
  • id:调用标识符。可以为字符串,不推荐包含小数(不能准确二进制化),或为null(可能引起混乱)。

3. 响应

服务器返回的数据格式也为JSON,其格式如下:

{
    "jsonrpc" : 2.0,
    "result" : "Hell JSON-RPC",
    "error" : null,
    "id" : 1
}
  • jsonrpc:定义JSON-RPC版本。
  • result:方法返回值,调用成功时,不能为null,调用错误时,必须为null。
  • error:调用时错误,无错误返回null,有错误时则返回一个错误对象。
  • id:调用标识符,与调用方传入的标识一致,当请求中的id检查发生错误时(转换错误/无效请求),则必须返回null。

4. 错误

4.1. 错误对象

{
    "code" : 1,
    "message" : "Nothing found",
    "data":null
}
  • code:一个表示错误类型的数字。
  • message:错误描述。
  • data:附加信息,可为null。

4.2. 错误码

错误码-32768到-32000作为预定义错误的保留值,该范围内的任何未定义代码为未来保留使用。

代码错误含义
-32700解析错误服务器接收到无效的JSON;服务器解析JSON文本发生错误。
-32600无效的请求发送的JSON不是一个有效的请求。
-32601方法未找到方法不存在或不可见。
-36602无效的参数无效的方法参数。
-36603内部错误JSON-RPC内部错误。
-32000到-32099服务器端错误保留给具体实现服务器端错误。

5. 批量调用

客户端可以发送一个请求对象数组来进行批量调用。当所有的请求都响应完毕后,服务器应以一个数组作为响应,每个请求都应该对应一个请求对象。服务器可以以任何宽度的并行性,以任意的顺序,并发的批量处理一个RPC调用。客户端可以通过id将请求和响应进行匹配。

6. 示例

6.1. 列表形式参数

请求

 {
    "jsonrpc":"2.0",
    "method": "subtract",
    "params":[42, 23],
    "id": 1
}

响应

 {
    "jsonrpc":"2.0",
    "result": 19,
    "id": 1
}

6.2. key-value形式参数

请求

 {
    "jsonrpc":"2.0",
    "method": "subtract",
    "params":{
                "subtrahend": 23,
                "minuend": 42
             }, 
    "id": 3
}

响应

 {
    "jsonrpc":"2.0",
    "result": 19,
    "id": 3
}

6.3. 错误的调用

(无id错误)
请求

{
    "jsonrpc":"2.0", 
    "method": 1, 
    "params": "bar"
}

响应

{
    "jsonrpc": "2.0", 
    "error":{
                "code": -32600, 
                "message": "Invalid Request"
            },
    "id": null
}

7. 参考文献

JSON-RPC轻量级远程调用协议介绍及使用

JSON-RPC2.0规范翻译中文版

posted @  2017-04-25 15:57  CieloSun 阅读( 4417) 评论( 1编辑  收藏

  
#1楼   2017-12-08 16:25  灿烂千阳   
6.3无ID错误应该怎么理解?
参考文献里的规范不是说无ID的情况下是通知,必须不回复一个通知吗?为什么要给出一个-32600错误响应呢?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值