hcnet
1.0.0
Нижний уровень виртуализированного сервера и клиента может легко переключать протоколы, такие как tcp/tcps/ws/wss/udp, чтобы облегчить переключение протоколов при любых обстоятельствах. Последующие требования, такие как онлайн-номер и управление потоком, будут обработаны позже.
Унифицированное использование обратных вызовов для функций обработки
/// 连接处理回调函数 # [ async_trait ] pub trait Handler { /// 此接口只有在服务端接受服务时进行触发 /// 接收新的端口连接, 如果处理将在此触发 async fn on_accept ( & mut self , conn : NetConn ) -> NetResult < ( ) > { let _conn = conn ; unreachable ! ( "Listener must impl accept" ) } /// 此接口在可以发送消息时触发 /// 例如websocket将在握手成功后触发该函数 async fn on_open ( & mut self ) -> NetResult < ( ) > { trace ! ( "ws on_open" ) ; Ok ( ( ) ) } /// 此接口在远程服务端被关闭时进行触发 async fn on_close ( & mut self , code : CloseCode , reason : String ) { trace ! ( "on_close code = {}, reason = {reason}" , Into :: < u16 > :: into ( code ) ) ; } /// ping消息收到, 将会自动返回pong消息 async fn on_ping ( & mut self , data : Vec < u8 > ) -> NetResult < Vec < u8 > > { trace ! ( "on_ping" ) ; Ok ( data ) } /// pong消息 async fn on_pong ( & mut self , data : Vec < u8 > ) -> NetResult < ( ) > { let _data = data ; trace ! ( "on_pong" ) ; Ok ( ( ) ) } /// message信息收到 async fn on_message ( & mut self , msg : Message ) -> NetResult < ( ) > { let _ = msg ; Ok ( ( ) ) } async fn on_request ( & mut self , req : Request < Vec < u8 > > ) -> NetResult < Response < Vec < u8 > > > { WsHandshake :: build_request ( & req ) } async fn on_response ( & mut self , res : Request < Vec < u8 > > ) -> NetResult < ( ) > { let _ = res ; Ok ( ( ) ) } }
NetConn :: tcp_bind ( "0.0.0.0:2003" , Settings :: default ( ) ) . await
NetConn :: ws_bind ( "0.0.0.0:2003" , Settings :: default ( ) ) . await
Настройка информации сертификата во время мониторинга позволяет легко поддерживать протокол wss.
let mut settings = Settings {
domain : Some ( "test.wmproxy.net" . to_string ( ) ) ,
cert : Some ( "key/example.com.pem" . to_string ( ) ) ,
key : Some ( "key/example.com.key" . to_string ( ) ) ,
.. Settings :: default ( )
} ;
NetConn :: ws_bind ( "0.0.0.0:2003" , settings ) . await
NetConn :: kcp_bind ( "0.0.0.0:2003" ) . await
По сути, мониторинг аналогичен обычному мониторингу сокетов, и его сложность аналогична. Вы можете переключать любой протокол по своему желанию.
let h = conn . run_handler ( |_| ServerHandler ) . await . unwrap ( ) ;
let _ = tokio :: join! ( h ) ;
Конкретные примеры см. в server_echo.
NetConn :: tcp_connect ( "127.0.0.1:2003" ) . await
NetConn :: ws_connect ( "ws://example.com:2003" ) . await
NetConn :: ws_connect ( "wss://example.com:2003" ) . await
NetConn :: kcp_connect ( "wss://example.com:2003" ) . await
let ( mut sender , receiver ) = NetSender :: new ( 10 , 1 ) ;
let _ = conn . run_with_handler (
ClientHandler {
sender : sender . clone ( ) ,
} ,
receiver ,
) . await ;
или
let _ = conn . run_handler ( |sender| ClientHandler { sender } ) . await ;
Конкретные примеры см. в client_echo.
Сначала запустите сервер
cargo run --example server_echo tcp
Перезапустите клиент
cargo run --example client_echo tcp