json-rpc笔记

文章目录

json-rpc是一种基于json的rpc(远程调用)协议。

示例

比较好理解,基于官网示例直接就明白了。

python 复制代码
--> {"jsonrpc": "2.0", "method": "subtract", "params": [42, 23], "id": 1}
<-- {"jsonrpc": "2.0", "result": 19, "id": 1}

--> {"jsonrpc": "2.0", "method": "subtract", "params": [23, 42], "id": 2}
<-- {"jsonrpc": "2.0", "result": -19, "id": 2}

通用

请求报文-模板

jsonrpc # jsonrpc版本,填2.0就行 必填

method # 方法名,对应 必填

id # 请求id 注:非必填`,如果不填表示是通知形式,不需要任何返回

param # 相当于常规json的请求体

模板:

json 复制代码
{
    "jsonrpc": "2.0",
    "method": "具体的方法名",
    "params": 具体的json请求体,可以是对象或数组
    "id": 请求id


}

返回报文

返回报文-模板(成功)

模板:

json 复制代码
{
    "jsonrpc": "2.0",
    "result": 返回结果,
    "id": 请求id
}
返回报文-模板(报错)
json 复制代码
{
    "jsonrpc": "2.0",
    "error": {
        "code": 具体错误码,
        "message": "具体错误信息",
        "data": "具体错误体,可以是任何类型,所以不能简单的用json转换,建议做类型判断",
    },
    "id": "具体请求id"
}

通知形式(容易忽略掉这种调用方式)

上面也提到了,如果不传id是一种特殊的请求形式,表示通知,不需要返回。

请求报文:

没有id。

返回报文:

不需要响应,也没有返回报文。

写代码时这里应该特殊处理下,如果按常规接收响应的话代码会报错。

其他

文档

官网地址(很简陋):

https://www.jsonrpc.org/specification

相关推荐
疯狂SQL3 天前
手写高性能在线 JSON 工具|Web Worker 工程化打包 + 语法自动修复 + 多语言代码生成实战
typescript·json·next.js·web worker·前端性能优化·esbuild·源码实战
LinXunFeng3 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
闪闪发亮的小星星8 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq8 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
小胖xiaopangss8 天前
BRpc使用
c++·rpc
阿米亚波8 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.8 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余8 天前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.8 天前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding
秋波。未央8 天前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习