1 个稳定版本
使用旧Rust 2015
8.0.0 | 2019年5月14日 |
---|
#17 在 #jsonrpc
24 每月下载
在 5 个crate中使用
49KB
1K SLoC
rs-jsonrpc-core
JSON-RPC 2.0规范的无传输实现Rust。
- - 服务器端
- - 客户端
示例
Cargo.toml
[dependencies]
rs-jsonrpc-core = "4.0"
main.rs
extern crate rs_jsonrpc_core;
use rs_jsonrpc_core::*;
fn main() {
let mut io = IoHandler::default();
io.add_method("say_hello", |_params: Params| {
Ok(Value::String("hello".into()))
});
let request = r#"{"jsonrpc": "2.0", "method": "say_hello", "params": [42, 23], "id": 1}"#;
let response = r#"{"jsonrpc":"2.0","result":"hello","id":1}"#;
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
}
异步响应
main.rs
extern crate rs_jsonrpc_core;
use rs_jsonrpc_core::*;
use rs_jsonrpc_core::futures::Future;
fn main() {
let io = IoHandler::new();
io.add_async_method("say_hello", |_params: Params| {
futures::finished(Value::String("hello".into()))
});
let request = r#"{"jsonrpc": "2.0", "method": "say_hello", "params": [42, 23], "id": 1}"#;
let response = r#"{"jsonrpc":"2.0","result":"hello","id":1}"#;
assert_eq!(io.handle_request(request).wait().unwrap(), Some(response.to_owned()));
}
发布-订阅
查看示例目录。
依赖
~1–1.9MB
~40K SLoC