webSocket前台实现

webSocket前台实现

简单实现:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script type="application/javascript" src="js/base64.js"></script>
    <script>
        var wsUri="ws:127.0.0.1:20000";
        var output;
        function init(e){
            output=document.getElementById("output");
            testWebSocket();
        }
        function testWebSocket(){
            websocket=new WebSocket(wsUri);
            //与服务器连接成功
            websocket.onopen=function(evt){
                onOpen(evt);
            }
            //服务器端关闭
            websocket.onclose = function(evt) {
                onClose(evt)
            };
            //接受传过来的数据
            websocket.onmessage = function(evt) {
                onMessage(evt)
            };
            //发送失败错误提示
            websocket.onerror = function(evt) {
                onError(evt)
            };
        }
        function onOpen(evt){
            document.getElementById("output").value="[user:127.0.0.1]#";
            doSend("WebSocket rocks");
        }
        function onClose(evt) {
            writeToScreen("DISCONNECTED");
        }

        function onMessage(evt) {
//            var b=new Base64();
//            alert(b.decode(evt.data));
            writeToScreen('<span style="color: blue;">RESPONSE: '+ evt.data+'</span>');
        }

        function onError(evt) {
            writeToScreen('<span style="color: red;">ERROR:</span> '+ evt.data);
        }

        function doSend(message) {
            if(websocket.readyState==1){
                alert("连接成功");
                websocket.send(message);
                setTimeout(function(){
                    if(websocket.readyState==1){
                        alert("无需尝试发送!");
                    }else{
                        alert("尝试发送");
                        doSend(message);
                    }
                },1000);
            }

        }
        function writeToScreen(message){
            var pre=document.createElement("p");
            pre.style.wordWrap="break-word";
            pre.innerHTML=message;
        }
        document.οnkeydοwn=function(e){
            var keycode=e.keyCode;
            if(keycode==13){
                doSend(document.getElementById("output").value);
            }
        }
        window.addEventListener("load",init,false);
    </script>
</head>
<body>
</body>
<h2>WebSocket Test</h2>
<input   id="output" style="width: 300px;height: 100px;background: black;color: whitesmoke;"></input>
</html>
vertx后台监听简单实现:
   Vertx vertx=Vertx.vertx();
vertx.createHttpServer().websocketHandler(res->{
ServerWebSocket server=res.resume();
server.handler(v->{
System.out.println(v);
});
server.write(Buffer.buffer("HTTP/1.1 101 Switching Protocols\nUpgrade: websocket\nConnection:Upgrade\nSec-WebSocket-Accept:izP3aDUEV5674E3AhIay4m1jU1c=\n\n\n".getBytes()));
System.out.println(server.path());
server.writeTextMessage("123");
}).listen(20000,res->{
if(res.succeeded()){
System.out.println("success");
}else{
System.out.println("fail");
}
});
---------------------  
作者:WX5991  
来源:CSDN  
原文:https://blog.csdn.net/WX5991/article/details/79108316  
版权声明:本文为博主原创文章,转载请附上博文链接!

转载于:https://my.oschina.net/airship/blog/2249054

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值