Solon v3.0.6

WebSokcet 客户端开发 (v2)

</> markdown

此内容 v2.6.0 后支持


1、Java 使用示例

开发 WebSocket 客户端,借助一个小工具 java-websocket-ns

<dependency>
    <groupId>org.noear</groupId>
    <artifactId>java-websocket-ns</artifactId>
    <version>1.1</version>
</dependency>

在 org.java-websocket 框架的基础上,加了点小便利:简化,心跳,自动重连,心跳定制。另外提醒:客户端的关闭使用 release() 替代 close()release() 会同时停止心跳与自动重连!

public class ClientApp {
    public static void main(String[] args) throws Throwable {
        //::启动客户端
        SimpleWebSocketClient client = new SimpleWebSocketClient("ws://127.0.0.1:18080") {
            //需要什么方法,就重写什么
            @Override
            public void onMessage(String message) {
                super.onMessage(message);
            }
        };

        //开始连接
        client.connectBlocking(10, TimeUnit.SECONDS);
        //开始心跳 + 心跳时自动重连
        client.heartbeat(20_000, true);

        //发送测试
        client.send("hello world!");

        //休息会儿
        Thread.sleep(1000);

        //关闭(使用 release 会同时停止心跳及自动重连)
        client.release();
    }
}

2、Javascript 使用示例

js 的原生 websocket 接口,没有自动心跳与断线重连,需要开发者自己处理。建议采用别的包装框架,或者升级为 socket.d 协议(带自动心跳与重连)

<script type="text/javascript">
    let client = new WebSocket("ws://127.0.0.1:18080/demoe/websocket/13?guid=2");
    
    client.onmessage = function (s, ev) {
        if(ev == 'pong'){ //模拟心跳 pong 接收
            return;
        }
         //加业务代码
    }
    
    setInterval(function(){
        client.send("ping"); //模拟心跳 ping 发送
    },15_000);

    //测试发送
    client.send("hello world!");
</script>

服务端的心跳模拟(有些“浏览器”端,没有实现心跳协议)

//服务端代码
public class DemoWs implements WebSocketListener {
    @Override
    public void onMessage(WebSocket socket, String text) throws IOException {
        if("ping".equals(text)){ //模拟心跳 ping 接收
            socket.send("pong"); //模拟心跳 pong 发送
            return;
        }
        
        ...
    }
    
    ...
}