#sockets #callback #tcp #websocket #ws #server-client

cbsk_socket

cbsk_socket是一个套接字回调工具

32个版本 (11个稳定版)

新版本 2.0.0 2024年8月21日
1.3.11 2024年8月19日
1.3.10 2024年7月26日
0.6.3 2024年4月11日
0.2.2 2023年12月29日

#671 in 数据结构

Download history 5/week @ 2024-05-02 282/week @ 2024-05-09 166/week @ 2024-05-16 33/week @ 2024-05-23 4/week @ 2024-05-30 175/week @ 2024-06-06 10/week @ 2024-06-13 3/week @ 2024-06-20 150/week @ 2024-06-27 11/week @ 2024-07-04 5/week @ 2024-07-11 122/week @ 2024-07-18 211/week @ 2024-07-25 29/week @ 2024-08-01 251/week @ 2024-08-15

每月493次下载
4个crate中使用(2个直接使用)

MIT/Apache

21KB
280

cbsk_socket是一个套接字回调工具
您可以使用cbsk_socket创建TCP/WebSocket服务器或客户端,您无需关注TCP/WebSocket的读写,只需关注业务处理即可

最低支持的Rust版本

Rust 1.80.0

现在支持的套接字

  • tcp客户端 √
  • tcp服务器 √
  • ws客户端 √
  • ws服务器 √

tcp服务器示例

tcp服务器示例

Cargo.toml文件

fast_log = "1.7.3"
cbsk_base = "2.0.0"
cbsk_socket_tokio = { version = "2.0.0", default-features = false, features = ["tcp_server"] }

main.rs文件

use std::net::{IpAddr, SocketAddr};
use std::sync::Arc;
use cbsk_base::{log, tokio};
use cbsk_base::async_trait::async_trait;
use cbsk_base::log::LevelFilter;
use cbsk_socket_tokio::cbsk_socket::tcp::server::config::TcpServerConfig;
use cbsk_socket_tokio::tcp::common::tcp_write_trait::TcpWriteTrait;
use cbsk_socket_tokio::tcp::server::callback::TcpServerCallBack;
use cbsk_socket_tokio::tcp::server::client::TcpServerClient;
use cbsk_socket_tokio::tcp::server::TcpServer;

#[tokio::main]
pub async fn main() {
    fast_log::init(fast_log::config::Config::default().level(LevelFilter::Info).console()).unwrap();
    let addr = SocketAddr::new(IpAddr::from([127, 0, 0, 1]), 8080);
    let conf = TcpServerConfig::new("".into(), addr, false);
    let tcp_server = TcpServer::new(conf.into(), Cb {});
    tcp_server.start().await;
}

struct Cb {}

#[async_trait]
impl TcpServerCallBack for Cb {
    async fn recv(&self, bytes: Vec<u8>, client: Arc<TcpServerClient>) -> Vec<u8> {
        log::info!("recv is {bytes:?}");
        client.send_bytes(b"hello client").await;
        Vec::with_capacity(1)
    }
}

tcp客户端示例

tcp客户端示例

Cargo.toml文件

fast_log = "1.7.3"
cbsk_base = "2.0.0"
cbsk_socket_tokio = "2.0.0" 

main.rs文件

use std::net::{IpAddr, SocketAddr};
use std::sync::LazyLock;
use std::time::Duration;
use cbsk_base::{log, tokio};
use cbsk_base::async_trait::async_trait;
use cbsk_base::log::LevelFilter;
use cbsk_socket_tokio::cbsk_socket::config::re_conn::SocketReConn;
use cbsk_socket_tokio::cbsk_socket::tcp::client::config::TcpClientConfig;
use cbsk_socket_tokio::tcp::client::callback::TcpClientCallBack;
use cbsk_socket_tokio::tcp::client::TcpClient;
use cbsk_socket_tokio::tcp::common::tcp_write_trait::TcpWriteTrait;

#[allow(non_upper_case_globals)]
static addr: LazyLock<SocketAddr> = LazyLock::new(|| { SocketAddr::new(IpAddr::from([127, 0, 0, 1]), 8080) });

#[allow(non_upper_case_globals)]
static tcp_client: LazyLock<TcpClient> = LazyLock::new(|| {
    let conf = TcpClientConfig::new("tcp client".into(), *addr, SocketReConn::enable(Duration::from_secs(3)));
    TcpClient::new(conf.into(), Cb {})
});

#[tokio::main]
pub async fn main() {
    fast_log::init(fast_log::config::Config::default().level(LevelFilter::Info).console()).unwrap();
    tcp_client.start().await;
}

struct Cb {}

#[async_trait]
impl TcpClientCallBack for Cb {
    async fn conn(&self) {
        tcp_client.send_bytes(b"hello server").await;
    }

    async fn recv(&self, bytes: Vec<u8>) -> Vec<u8> {
        log::info!("bytes is {bytes:?}");
        tcp_client.send_bytes(b"hello server").await;
        Vec::with_capacity(1)
    }
}

依赖项

~0–6.5MB
~39K SLoC