8 个版本

0.3.9 2024年8月8日
0.3.8 2024年7月17日
0.3.6 2024年5月13日
0.3.4 2024年2月24日
0.1.2 2023年11月14日

#2#conn

Download history 224/week @ 2024-05-11 24/week @ 2024-05-18 8/week @ 2024-05-25 1/week @ 2024-06-01 54/week @ 2024-06-29 55/week @ 2024-07-06 151/week @ 2024-07-13 11/week @ 2024-07-20 14/week @ 2024-07-27

每月下载量 280

自定义许可协议

18KB
415

Rconn

这是一个具有自己协议的简单网络服务。

使用方法

创建服务器

use std::{
    net::TcpStream,
    sync::{Arc, Mutex},
};

use rconn::{
    conn::{RConnection, RHandle, THandle},
    rhandle_impl_new,
    server::{serde::Serialize, serde_json::Value, Server},
    Lazy,
};

struct Handler;

rhandle_impl_new!(Handler);

impl Default for Handler {
    fn default() -> Self {
        Handler {}
    }
}

#[derive(Serialize)]
struct Response {
    result: String,
}

impl RHandle for Handler {
    fn handle(&mut self, tcp: &mut TcpStream, _: &Value, _: &Vec<u8>) {
        let resp = Response {
            result: String::from("OK"),
        };
        let cusd = Vec::new();
        Server::send_data(tcp, &resp, &cusd);
    }
}

static MAIN_HANDLER: Lazy<THandle> = Lazy::new(|| Handler::new());

fn matcher(act: &str) -> THandle {
    println!("Matcher: match {}", act);
    match act {
        _ => MAIN_HANDLER.clone(),
    }
}

fn main() {
    let mut s = Server::new("0.0.0.0:5000", 16);
    s.set_matcher(&matcher);
    s.start();
}

客户端

use crate::client::{
    serde::{Deserialize, Serialize},
    Client,
};

#[derive(Serialize, Deserialize)]
struct Test;

fn main() {
    let mut client = Client::new("127.0.0.1", 5000, 10000).unwrap();
    let ndata = Test {};
    let cusd = Vec::new();
    let readed = client.request("test", &ndata, &cusd).unwrap();
    println!("Get: {:?}", readed);
}

依赖项

~2–3MB
~62K SLoC