`
eimhee
  • 浏览: 2112295 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Start PageIndexHistoryLast Change

阅读更多
The specifications should provide the developer with the information needed to implement the protocol.

NOTE: The JSON-RPC 2.0 Specification proposal has been published and open for review and comments.

Overview¶
JSON-RPC is a lightweight remote procedure call protocol. It's designed to be simple!

The general mechanism consists of two peers establishing a data connection. During the lifetime of a connection, peers may invoke methods provided by the other peer. To invoke a remote method, a request is sent. Unless the request is a notification it must be replied to with a response.

1.1 Request (method invocation)¶
A remote method is invoked by sending a request to a remote service. The request is a single object serialized using JSON.

It has three properties:

•method - A String containing the name of the method to be invoked.
•params - An Array of objects to pass as arguments to the method.
•id - The request id. This can be of any type. It is used to match the response with the request that it is replying to.
1.2 Response¶
When the method invocation completes, the service must reply with a response. The response is a single object serialized using JSON.

It has three properties:

•result - The Object that was returned by the invoked method. This must be null in case there was an error invoking the method.
•error - An Error object if there was an error invoking the method. It must be null if there was no error.
•id - This must be the same id as the request it is responding to.
1.3 Notification¶
A notification is a special request which does not have a response. The notification is a single object serialized using JSON.

It has the same properties as the request object with one exception.

•id - Must be null.
2.1 JSON-RPC over stream connections¶
The specifications do not require a certain transport protocol. The use of TCP/IP socket streams is encouraged. The serialized request and response objects are sent to the peers through the byte streams.

Requests and responses may be sent to a peer at any time. The peer must respond to each request unless it is a notification. A response may only be sent in reply to a request.

Closing the connection between peers must raise an exception for all unanswered requests on each peer. Non-valid requests or responses must result in closing the connection.

2.2 JSON-RPC over HTTP¶
With some limitation, HTTP requests can be used as a transport for communicating between peers.

A communication between peers, one being an HTTP client the other an HTTP server, may span multiple HTTP requests. A client side peer may send one or more requests, notifications or responses to its peer by sending an HTTP POST request containing all serialized objects.

The server side peer must reply with responses to all requests sent and may send requests or notifications of its own. The client side peer must reply to requests received by sending another HTTP POST.

To give the serverside peer a chance to send messages to the client side peer, the client side peer may reopen communication by sending an empty HTTP POST.

A non-valid request must result in closing the connection. A non-valid response must raise an exception for all unanswered requests on the client. Closing a connection must raise an exception for all unanswered requests on the client.

FIXME: Describe/define how sessions are handled, as there is no implicit session formed by a TCP-connection.

3. JSON Class hinting¶
There are only simple data types defined in JSON. To overcome this problem in a JSON compatible way a special property for objects is introduced.
{"__jsonclass__":["constructor", [param1,...]], "prop1": ...}
The object is then instantiated using the constructor, passing in the parameters. Once constructed the properties (prop1, ...) will be applied.

4. Communication Examples¶
--> data sent to service
<-- data coming from service

•service.echo("Hello JSON-RPC")
--> { "method": "echo", "params": ["Hello JSON-RPC"], "id": 1}
<-- { "result": "Hello JSON-RPC", "error": null, "id": 1}
•multiple request responses
This example shows parts of a communication from an example chat application. The chat service sends notifications for each chat message the client peer should receive. The client peer sends requests to post messages to the chat and expects a positive reply to know the message has been posted.

...

--> {"method": "postMessage", "params": ["Hello all!"], "id": 99}
<-- {"result": 1, "error": null, "id": 99}
<-- {"method": "handleMessage", "params": ["user1", "we were just talking"], "id": null}
<-- {"method": "handleMessage", "params": ["user3", "sorry, gotta go now, ttyl"], "id": null}
--> {"method": "postMessage", "params": ["I have a question:"], "id": 101}
<-- {"method": "userLeft", "params": ["user3"], "id": null}
<-- {"result": 1, "error": null, "id": 101}
...
分享到:
评论

相关推荐

    Windows 7 Start Button Change

    Windows 7的开始按钮非常漂亮,但看久了也会“审美疲劳”,这个名为Windows 7 Start Button Changer的小工具,就是用来替换开始按钮样式的。据说是一个12岁的小网民开发的。  用法非常简单,选择要替换的源文件,再...

    changeip的ddns更新客户端【curl实现changeip的ddns动态域名更新功能】

    通过批处理调用curl来进行changeip的ddns更新,解压到本地某路径,简单修改一下帐户和域名信息,点击start.bat直接运行即可。 参数说明: set user=用户名 set password=密码 set domain=你的ddns set url=...

    electron-quick-start-master 快速入门教程

    electron-quick-start-master 快速入门教程electron-quick-start-master 快速入门教程electron-quick-start-master 快速入门教程electron-quick-start-master 快速入门教程electron-quick-start-master 快速入门教程...

    Win10开始菜单修复工具Windows 10 Start Menu TroubleShooter下载

    Start Menu does not open or not working in Windows 10 Win10开始菜单修复工具Windows 10 Start Menu TroubleShooter下载 这个微软官方Win10开始菜单修复工具是一个单文件的大小只有398KB的小工具,文件名为start...

    start-stop-daemon

    linux系统命令start-stop-daemon的源码及二进制,其中也提供了一个服务启动脚本模板。 此程序能帮助你实现将命令行程序变成服务运行,比如将"java -jar xxx.jar" 放在后台执行。 ./start-stop-daemon --help start-...

    oracle数据库startwith用法

    oracle数据库startwith用法

    打印机驱动 实达Start BP-750KII 驱动

    打印机驱动 实达Start BP-750KII 驱动打印机驱动 实达Start BP-750KII 驱动打印机驱动 实达Start BP-750KII 驱动打印机驱动 实达Start BP-750KII 驱动打印机驱动 实达Start BP-750KII 驱动打印机驱动 实达Start BP-...

    startServer.sh

    startServer.sh

    打印机驱动 START_PLQ6_OKI5_Drvsky

    打印机驱动 START_PLQ6_OKI5_Drvsky打印机驱动 START_PLQ6_OKI5_Drvsky打印机驱动 START_PLQ6_OKI5_Drvsky打印机驱动 START_PLQ6_OKI5_Drvsky打印机驱动 START_PLQ6_OKI5_Drvsky打印机驱动 START_PLQ6_OKI5_Drvsky...

    starTFTP.EXE

    starTFTP.EXE 最易用的tftp软件

    42 Reasons To Start a Business Analyst Career

    42 Reasons To Start a Business Analyst Career

    spring boot/spring cloud项目启动脚本,默认名称:start.sh

    linux服务器,springboot,spring cloud、spring ...sh start.sh start sh start.sh stop sh start.sh restart sh start.sh status 或者: ./start.sh start ./start.sh stop ./start.sh restart ./start.sh status

    Win8开始菜单软件Start8破解

    1.安装Start8-setup.exe。 1.禁用Stardock Start8服务,重启电脑。 2.根据不同系统查看Start8Shell32.dll或Start8Shell64.dll是否被占用,解除占用或是进入安全模式进行破解。 (破解时这个DLL一定不能被占用,否则...

    Windows 10 Start menu troubleshooter

    该工具是用于修复win10菜单栏,鼠标点击无反应的情况。 Windows 10 Start menu troubleshooter

    The required Server component failed to start so Tomcat is unable to start问题解决

    亲测解决tomcat9.08搭配jkd9,搭建servlet环境。常见问题是,The required Server component failed to start so Tomcat is unable to start。这个问题,直接通过配置eclipse来解决这个问题。

    ARM中start.s详解

    很不错的底层程序详解。参考了别人的一些资料。 对于初学者学习start很有帮助!

    打印机驱动 实达Start BP-690KPro 票据打印机驱动

    打印机驱动 实达Start BP-690KPro 票据打印机驱动打印机驱动 实达Start BP-690KPro 票据打印机驱动打印机驱动 实达Start BP-690KPro 票据打印机驱动打印机驱动 实达Start BP-690KPro 票据打印机驱动打印机驱动 实达...

    startuml使用手册

    startuml使用手册startuml使用手册startuml使用手册startuml使用手册startuml使用手册startuml使用手册startuml使用手册startuml使用手册startuml使用手册startuml使用手册

    打印机驱动 START_BP-690K

    打印机驱动 START_BP-690K打印机驱动 START_BP-690K打印机驱动 START_BP-690K打印机驱动 START_BP-690K打印机驱动 START_BP-690K打印机驱动 START_BP-690K打印机驱动 START_BP-690K打印机驱动 START_BP-690K打印机...

    startUML建模工具

    startUML建模工具 startUML建模工具startUML建模工具startUML建模工具startUML建模工具

Global site tag (gtag.js) - Google Analytics