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

本贴最后更新于 2612 天前,其中的信息可能已经斗转星移

原文

技术简介

json-rpc 是基于 json 的跨语言远程调用协议,比 xml-rpc、webservice 等基于文本的协议传输数据格小;相对 hessian、java-rpc 等二进制协议便于调试、实现、扩展,是非常优秀的一种远程调用协议。目前主流语言都已有 json-rpc 的实现框架,java 语言中较好的 json-rpc 实现框架有 jsonrpc4j、jpoxy、json-rpc。三者之中 jsonrpc4j 既可独立使用,又可与 spring 无缝集合,比较适合于基于 spring 的项目开发。

一、JSON-RPC 协议描述

json-rpc 协议非常简单,发起远程调用时向服务端传输数据格式如下:

{ "method": "sayHello", "params": ["Hello JSON-RPC"], "id": 1}

参数说明:

method: 调用的方法名

params: 方法传入的参数,若无参数则传入 []

id : 调用标识符,用于标示一次远程调用过程

服务器其收到调用请求,处理方法调用,将方法效用结果效应给调用方;返回数据格式:

 {   
    "result":          "Hello JSON-RPC",         
    "error":                null,       
      "id":                      1
 }                        

参数说明:

result: 方法返回值,若无返回值,则返回 null。若调用错误,返回 null。

error :调用时错误,无错误返回 null。

id : 调用标识符,与调用方传入的标识符一致。

以上就是 json-rpc 协议规范,非常简单,小巧,便于各种语言实现。

二、JSON-RPC 简单示例

2.1、服务器端 Java 调用示例

jsonrpc4j 服务器端 java 示例:

public class HelloWorldServlet extends HttpServlet {

**private** **static** **final** **long** _serialVersionUID_ = 3638336826344504848L;

**private** JsonRpcServer rpcService = **null**;

@Override

**public** **void** init(ServletConfig config) **throws** ServletException {

    **super**.init(config);

    rpcService = **new** JsonRpcServer(**new** HelloWorldService(), HelloWorldService.**class**);

}

@Override

**protected** **void** service(HttpServletRequest req, HttpServletResponse resp)

        **throws** ServletException, IOException {

    rpcService.handle(req, resp);    

}

}

2.2、Java 客户端调用示例

jsonrpc4j 的 Java 客户端调用示例:

    JsonRpcHttpClient client = **new** JsonRpcHttpClient(

         **new** URL("http://127.0.0.1:8080/index.json"));

    Map headers = **new** HashMap();

    headers.put("name", "剑白");

 client.setHeaders(headers);

    String properties = client.invoke("getSystemProperties", **null**, String.**class**);

    System._out_.println(properties);

2.3、PHP 客户端调用示例

基于 json-rpc-php 的 PHP 客户端调用示例:

include(dirname(FILE)."/lib/client/JsonRpcClient.php");

$client = new JsonRpcClient("http://10.13.49.234:8080/index.json");

response = client->getSystemProperties();

echo $response->result;

?>

2.3、JavaScript 客户端调用示例

基于 jsonrpcjs 的 JavaScript 客户端调用示例:

var rpc = new jsonrpc.JsonRpc('http://127.0.0.1:8080/index.json');

rpc.call('getSystemProperties', function(result){

alert(result);

});

2.4、直接 GET 请求进行调用

无需任何客户端,只需手工拼接参数进行远程调用,请求 URL 如下:

http://127.0.0.1:8080/index.json?method=getSystemProperties&id=3325235235235¶ms=JTViJTVk

参数说明:

method : 方法名

params :调用参数,json 的数组格式[], 将参数需先进行 url 编码,再进行 base64 编码

id : 调用标识符,任意值。

三、JSON-RPC 总结

json-rpc 是一种非常轻量级的跨语言远程调用协议,实现及使用简单。仅需几十行代码,即可实现一个远程调用的客户端,方便语言扩展客户端的实现。服务器端有 php、java、python、ruby、.net 等语言实现,是非常不错的及轻量级的远程调用协议。

参考文档

http://code.google.com/p/jsonrpc4j/

http://json-rpc.org/wiki/implementations

http://en.wikipedia.org/wiki/JSON-RPC

https://github.com/gimmi/jsonrpcjs

http://bitbucket.org/jbg/php-json-rpc

https://github.com/Pozo/json-rpc-php

https://github.com/subutux/json-rpc2php

  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3187 引用 • 8213 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...