gpt4 book ai didi

rust - 如何使用hyper添加多个RPC端点?

转载 作者:行者123 更新时间:2023-12-03 11:46:05 25 4
gpt4 key购买 nike

我想使用hyper创建多个RPC方法。 This is their example code。如何添加多个方法并启动返回BoxFuture的服务?

在下面,我有两种方法,如何合并这两种方法并创建服务?

use hyper::service::{make_service_fn, service_fn};
use hyper::{Body, Request, Response, Server};
use std::{convert::Infallible, net::SocketAddr};

async fn gas_Price(_: Request<Body>) -> Result<Response<Body>, Infallible> {
Ok(Response::new(Body::from("{id:1,jsonrpc:2.0,result:0x0}")))
}


async fn eth_Transaction(_: Request<Body>) -> Result<Response<Body>, Infallible> {
Ok(Response::new(Body::from("eth_Transcation!")))
}

#[tokio::main]
pub async fn Start() {
let addr = SocketAddr::from(([127, 0, 0, 1], 3030));

let make_svc = make_service_fn(|_conn| async { Ok::<_, Infallible>(service_fn(gas_Price)) });

let server = Server::bind(&addr).serve(gas_Price);

if let Err(e) = server.await {
eprintln!("server error: {}", e);
}
}

最佳答案

我过去采用的一种方法是使一种服务充当路由表。
我编写的服务只包含匹配路径和http方法的匹配项,然后在每个分支中调用适当的函数。

例如:

pub async fn route(req: Request<Body>) -> Result<Response<Body>, hyper::Error> {
let mut response = Response::new(Body::empty());


let method = req.method().clone();
let uri = req.uri().clone();
let path = uri.path();
let full_body = hyper::body::to_bytes(req.into_body()).await?;
let val = serde_json::from_slice::<Value>(&full_body)?;

match (method, path) {
(Method::POST, "/some-enpoint") => {
let new_body = appropriate_function(&val);
*response.body_mut() = Body::from(new_body);
},

(_method, _path) => {
*response.status_mut() = StatusCode::NOT_FOUND;
}
}
Ok(response)
}

我不知道这是否是处理Hyper中问题的推荐方法,但它对我构建的事情效果很好。

关于rust - 如何使用hyper添加多个RPC端点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60180283/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com