轻量级通信协议 JSON-RPC 2.0 详解

目录

JSON-RPC 2.0 简介

请求对象

响应对象

通知

批量请求

错误码

使用场景

文档和版本控制

社区和支持

小结

参考资料


JSON-RPC 2.0 简介

JSON-RPC (JavaScript Object Notation - Remote Procedure Call) 是一种轻量级的远程过程调用协议,使用 JSON(JavaScript 对象表示法)作为数据格式。JSON-RPC 2.0 是该协议的最新版本,在 1.0 版本的基础上增加了一些特性,如错误代码标准化、批量请求支持和无响应的通知。

JSON-RPC 的设计原则是简单性和互操作性,旨在为不同编程语言之间提供一种方便的方法来执行远程过程调用。通过定义一组简单的规则,任何能够解析 JSON 的语言或平台都可以实现 JSON-RPC 客户端或服务器。

接下来看下 JSON-RPC 2.0 协议的规范。

请求对象

一个 JSON-RPC 2.0 请求数据是一个单一的 JSON 对象,可以包含以下成员:

  • jsonrpc:字符串,指定 JSON-RPC 的版本号,对于 2.0 规范来说,这个值必须是 2.0。
  • method:字符串,指定要调用的远程方法的名称。
  • params:结构化值,可以是数组或者对象,传递给远程方法的参数。如果方法不需要参数可以省略。
  • id:唯一标识符,可以是字符串或数字,用于关联请求和响应,服务端必须返回相同的值。如果请求是一个通知类型,则此参数可以被省略。

一个标准的 JSON-RPC 2.0 请求示例如下:

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

响应对象

一个 JSON-RPC 2.0 响应数据也是一个单一的 JSON 对象,可以包含以下成员:

  • jsonrpc:字符串,指定 JSON-RPC 的版本号,对于 2.0 规范来说,这个值必须是2.0。
  • result:当请求成功时,包含由远程方法返回的结果。如果请求失败,则不包含此成员。
  • error:当请求失败时,包含一个错误对象。如果请求成功,则不包含此成员。
  • id:与请求中的 id 相同,用于识别哪个请求对应的响应。

错误对象包括以下成员:

  • code:整数,用于说明错误类型。JSON-RPC 2.0 定义了一组标准的错误码。
  • message:字符串,提供关于错误的简短描述。
  • data:可选,可以包含额外的错误信息,比如堆栈信息等。

一个成功的响应示例如下:

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

而一个异常响应示例如下:

{"jsonrpc": "2.0","error": {"code": -32601,"message": "Method not found"},"id": 1
}

通知

通知是一种特殊类型的请求,没有 id 成员,因此不会得到响应。这样客户端可以向服务器发送事件或命令而无需等待回复。一个通知示例如下:

{"jsonrpc": "2.0","method": "updateStatus","params": ["online"]
}

批量请求

JSON-RPC 2.0 支持批量请求,即可以在单个请求中发送多个 JSON-RPC 调用。每个调用都是独立的 JSON-RPC 请求对象,被放在一个数组中。服务器处理这些请求后返回一个数组,其中每个元素对应于一个调用。需要注意的是,如果其中一个调用是通知,则不会有对应的响应项。

[{"jsonrpc": "2.0","method": "sum","params": [1, 3, 5, 7, 9],"id": "1"},{"jsonrpc": "2.0","method": "notify_hello","params": ["Alice"]},{"jsonrpc": "2.0","method": "subtract","params": [42, 23],"id": "2"}
]

错误码

JSON-RPC 2.0 规范中定义了标准的错误码,但开发者也可以根据自己的业务逻辑添加自定义的错误码。这些自定义错误代码应该在-32000到-32099之间,以避免与标准错误码冲突。通过使用自定义错误码,可以为客户端提供更加具体的错误信息。

假如这样一个场景,应用程序需要处理用户认证失败的情况,可以定义一个特定的错误码,比如 -32001,并为这个错误码配一个说明,如 Authentication failed。示例如下:

{"jsonrpc": "2.0","error": {"code": -32001,"message": "Authentication failed"},"id": "1"
}

此外,还可以在  error 的 data 参数中包含更多的错误细节,比如错误发生的具体位置或建议的解决方法。

JSON-RPC 2.0 定义的标准错误码如下(自定义错误吗不要使用如下几个):

  • -32700: 解析错误,服务器收到无效的 JSON。
  • -32600: 无效请求,发送的 JSON 不是有效的请求对象。
  • -32601: 方法未找到,方法不存在或无效。
  • -32602: 无效参数,提供的参数无效。
  • -32603: 内部错误,JSON-RPC 内部错误。

使用场景

JSON-RPC 2.0 的使用场景包括但不限于如下几个:

  • Web 应用程序,客户端与服务器之间的异步通信,例如浏览器与后端服务交互。
  • 微服务之间的通信,通过 JSON-RPC 调用其他微服务的接口。
  • 物联网设备,设备与服务器之间的通信,由于 JSON-RPC 的轻量级特性,非常适合资源受限的设备。
  • 移动应用,移动客户端与服务器之间的交互,减少数据传输量,提高响应速度。
  • 区块链和加密货币,节点之间的通信或客户端与节点的交互,许多区块链系统(如以太坊)使用 JSON-RPC 进行接口调用。
  • 远程过程调用(RPC)服务,替代传统的 SOAP 或 XML-RPC,提供简单的接口调用机制。

文档和版本控制

良好的文档对于任何 API 都至关重要,尤其是像 JSON-RPC 2.0 这样依赖于明确的请求和响应格式的协议。

  • 编写清晰的 API 文档:详细描述每个方法的用途、参数、返回值和可能的错误情况。可以使用工具如 Swagger 或 Postman 来生成交互式的 API 文档。
  • 保持文档更新:随着 API 的发展,确保文档始终保持最新状态,反映最新的变更和改进。
  • 版本控制:为 API 引入版本控制,以便在不影响现有用户的情况下进行更新。可以在 URL 中或通过请求头指定 API 版本。

社区和支持

JSON-RPC 2.0 是一个开放的标准,拥有活跃的社区和丰富的资源。参与社区讨论、阅读官方文档和技术博客、关注相关论坛和社交媒体,都可以帮助更快地解决问题,并获取最新的最佳实践。

此外,很多流行的编程语言和框架都有现成的 JSON-RPC 库,可以大大简化开发过程。选择一个成熟且维护良好的库,不仅可以节省时间,还能减少出错的可能性。

小结

JSON-RPC 2.0作为一种轻量级的 RPC 协议,提供了如标准化的错误处理、批量请求支持和通知机制等功能,具有简单、易用、跨语言等优点,适用于多种分布式系统场景。

参考资料

  • https://www.jsonrpc.org/specification

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/65163.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ffmpeg之h264格式转yuv

h264格式转yuv详细步骤 初始化FFmpeg库:通过av_register_all()来初始化必要的组件。打开输入文件并查找解码器:使用avformat_open_input和 avcodec_find_decoder 打开H.264文件,并查找视频流。分配并配置解码上下文:使用 avcodec…

创建VUE脚手架

1.输入 npm create vuelatest2.创建完成

vue3如何实现防抖?

第一 防抖就是我们设置一个调用时间&#xff0c;点击后设置时间开始倒计时&#xff0c;如果再次点击会重新倒计时 npm或yarn安装&#xff1a; npm install lodash <template><div click"debouncedInputHandler"><button>打印</button>…

JavaWeb开发(六)XML介绍

1. XML介绍 1.1. 什么是XML &#xff08;1&#xff09;XML 指可扩展标记语言(EXtensible Markup Language)XML 是一种很像HTML的标记语言。   &#xff08;2&#xff09;XML 的设计宗旨是传输数据(目前主要是作为配置文件)&#xff0c;而不是显示数据。   &#xff08;3&a…

用shell把(1到100)100个整数写入到二进制文件

author: hjjdebug date: 2025年 01月 05日 星期日 16:14:41 CST description: 用shell把(1到100)100个整数写入到二进制文件 1. 问题分析(需求分析) 在c语言下, 整数int 是按4个字节存储的,能表示最大0xffffffff的范围 但shell并没有一条命令能够实现把一个整数写入二进制文件…

SpringBoot下载文件的几种方式

小文件&#xff1a;直接将文件一次性读取到内存中&#xff0c;文件大可能会导致OOM GetMapping("/download1")public void download1(HttpServletResponse response) throws IOException {// 指定要下载的文件File file new File("C:\\Users\\syd\\Desktop\\do…

Flink使用

Window下启动支持 下载或复制老版本的放在bin目录下即可&#xff1b; flink.bat echo off setlocalSET bin%~dp0 SET FLINK_HOME%bin%.. SET FLINK_LIB_DIR%FLINK_HOME%\lib SET FLINK_PLUGINS_DIR%FLINK_HOME%\pluginsSET JVM_ARGS-Xmx512mSET FLINK_JM_CLASSPATH%FLINK_LI…

Python基础知识回顾-数据结构

Tuple 在 Python 中&#xff0c;我们经常使用 Tuple 来将相关数据分组。Tuple 指的是有序且不可变的元素集合。 形式&#xff1a;通常以逗号分隔的元素写在括号"() "中。 数据类型和索引&#xff1a;包含 String、整数和浮点数&#xff0c;并使用正索引和负索引访问…

8. C++ 面向对象之特性一(封装)

面向对象主要包括三大类&#xff1a;封装&#xff0c;继承&#xff0c;多态 1.类和对象 c认为&#xff0c;万物皆为对象&#xff0c;对象上有其属性和行为 人可以作为对象&#xff0c;属性有姓名、年龄、身高、体重...&#xff0c;行为有走、跑、跳、吃饭、唱歌... 车也可以作…

WebRtc02:WebRtc架构、目录结构、运行机制

整体架构 WebRtc主要分为三层&#xff1a; CAPI层&#xff1a;外层调用Session管理核心层&#xff1a;包括视频引擎、音频引擎、网络传输 可由使用者重写视频引擎&#xff1a;编解码器、视频缓存、视频增强音频引擎&#xff1a;编解码器、音频缓存、回音消除、降噪传输&#x…

【Qt】快速添加对应类所需的头文件包含

快速添加对应类所需的头文件包含 一&#xff0c;简介二&#xff0c;操作步骤 一&#xff0c;简介 本文介绍一下&#xff0c;如何快速添加对应类所需要包含的头文件&#xff0c;可以提高开发效率&#xff0c;供参考。 二&#xff0c;操作步骤 以QTime类为例&#xff1a; 选中…

Apache MINA 反序列化漏洞CVE-2024-52046

漏洞描述&#xff1a; Apache MINA 是一个功能强大、灵活且高性能的网络应用框架。它通过抽象网络层的复杂性&#xff0c;提供了事件驱动架构和灵活的 Filter 链机制&#xff0c;使得开发者可以更容易地开发各种类型的网络应用。 Apache MINA 框架的 ObjectSerializationDeco…

服务器docker配置过程

1.docker安装 参考官方文档&#xff1a;https://docker.cadn.net.cn/manuals/engine_install_ubuntu 2.docker镜像源替换 官方文档&#xff1a;https://cloud.tencent.com/document/product/1207/45596 镜像源根据你租了哪家的去找官方文档即可。

RabbitMQ通过代码创建交换机和队列

常见交换机 RabbitMQ提供的交换机一共的四种&#xff0c;分别是&#xff1a; 1. Fanout&#xff1a;采用广播形式来发送消息&#xff0c;会将消息路由到所有绑定了的队列之中。 2. Direct&#xff1a;通过Binding Key与队列绑定&#xff0c;生产者在发送信息的时候会通过Routin…

js es6 reduce函数, 通过规格生成sku

const specs [{ name: 颜色, values: [红色, 蓝色, 绿色] },{ name: 尺寸, values: [S, M, L] } ];function generateSKUs(specs) {return specs.reduce((acc, spec) > {const newAcc [];for (const combination of acc) {for (const value of spec.values) {newAcc.push(…

WPF通过反射机制动态加载控件

Activator.CreateInstance 是 .NET 提供的一个静态方法&#xff0c;它属于 System 命名空间。此方法通过反射机制根据提供的类型信息。 写一个小demo演示一下 要求&#xff1a;在用户反馈界面点击建议或者评分按钮 弹出相应界面 编写MainWindow.xmal 主窗体 <Window x:C…

宽带、光猫、路由器、WiFi、光纤之间的关系

1、宽带&#xff08;Broadband&#xff09; 1.1 宽带的定义宽带指的是一种高速互联网接入技术&#xff0c;通常包括ADSL、光纤、4G/5G等不同类型的接入方式。宽带的关键特点是能够提供较高的数据传输速率&#xff0c;使得用户可以享受到稳定的上网体验。 1.2 宽带的作用宽带是…

Pytest钩子函数,测试框架动态切换测试环境

在软件测试中&#xff0c;测试环境的切换是个令人头疼的问题。不同环境的配置不同&#xff0c;如何高效切换测试环境成为许多测试开发人员关注的重点。你是否希望在运行测试用例时&#xff0c;能够动态选择测试环境&#xff0c;而不是繁琐地手动修改配置&#xff1f; Pytest 测…

印象笔记07——试一试PDF标注

印象笔记07——试一试PDF标注 [!CAUTION] 根据第六期&#xff0c;我再次查询了资料&#xff0c;印象笔记还是有一些可圈可点的功能的&#xff08;当然部分有平替&#xff09;&#xff0c;针对会员作用&#xff0c;开发使用场景虽然是逆向的&#xff0c;但我坚信这是一部分人的现…

【Vue】分享一个快速入门的前端框架以及如何搭建

先上效果图: 登录 菜单: 下载地址: 链接&#xff1a;https://pan.baidu.com/s/1m-ZlBARWU6_2n8jZil_RAQ 提取码&#xff1a;ui20 … 主要是可以自定义设置token,更改后端请求地址较为方便。 应用设置: 登录与token设置: 在这里设置不用登录,可以请求的接口: request.js i…