hermes-jsonrpc icon indicating copy to clipboard operation
hermes-jsonrpc copied to clipboard

使用 GSON/Protostuff 的轻量级HTTP协议的Java Json Rpc框架

hermes-jsonrpc Build Status Coverage Status

A Java-Version light-weight HTTP-JSON RPC framework using GSON/Protostuff.

使用 GSON/Protostuff 的轻量级HTTP协议的Java Json Rpc框架

hermes-jsonrpc branches and Maven version:

  • dev(develop branch): 1.0.3
  • master(stable branch):1.0.3

在Maven Central Repository里查看 com.github.knightliao.hermesjsonrpc

项目信息

  • Java项目(1.6+)
  • Maven管理(3.0.5+)

它是什么?

  • 命名为hermes-jsonrpc
  • 专注于高效、高速、简单的 Java Json Rpc 编程

Features

  • 协议:HTTP
  • 传输格式:JSON
  • codec协议: GSON 或 Protostuff
  • Client编程方式:
    • 支持Spring AOP代理方式请求方式
  • Server编程方式:
    • 支持Spring Web Servlet接受请求方式
    • 支持安全的 用户名/密码验证(无法反算)
    • 支持白名单
    • 支持接受GET请求,它显示接口信息。GET请求支持白名单
  • 同步调用,不支持异步调用

注:本框架遵循的规范可参见: https://github.com/knightliao/docs/blob/master/baidu/rpc/rpcspec.md

协议规范示例

Java接口:

link

client request示例(在没有权限控制的情况下):

curl -d '{"id":"99999","version":"2.0","method":"getRandom","params":[{"maxValue":0,"minValue":50}]}' http://127.0.0.1:8085/export/DemoServiceDriver -H 'Content-Type: application/json-hermes-gson'

server response示例(在没有权限控制的情况下):

{"result":{"value":32},"version":"2.0","id":99999}

使用

在您的 Maven POM 文件里加入:

client:

<dependency>
    <groupId>com.github.knightliao.hermesjsonrpc</groupId>
    <artifactId>hermes-jsonrpc-client</artifactId>
    <version>1.0.3</version>
</dependency>

server:

<dependency>
    <groupId>com.github.knightliao.hermesjsonrpc</groupId>
    <artifactId>hermes-jsonrpc-server</artifactId>
    <version>1.0.3</version>
</dependency>

Tutorials

局限性

  • 服务和客户端均只能是Java语言编程
  • 不支持异步调用