博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
webSocket前台实现
阅读量:5886 次
发布时间:2019-06-19

本文共 2416 字,大约阅读时间需要 8 分钟。

hot3.png

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

你可能感兴趣的文章
判断点是否在三角形内
查看>>
知行合一
查看>>
jmeter插件之jsonpath提取响应结果和做断言
查看>>
[Contiki系列论文之1]Contiki——为微传感器网络而生的轻量级的、灵活的操作系统...
查看>>
Android 网络编程 记录
查看>>
微软同步发行Windows 10和Windows 10 Mobile系统更新
查看>>
Zeppelin的入门使用系列之使用Zeppelin运行shell命令(二)
查看>>
form表单下的button按钮会自动提交表单的问题
查看>>
那些年追过的......写过的技术博客
查看>>
python基础教程_学习笔记19:标准库:一些最爱——集合、堆和双端队列
查看>>
CSS魔法堂:Transition就这么好玩
查看>>
C/C++ 多线程机制
查看>>
如何使用Core Text计算一段文本绘制在屏幕上之后的高度
查看>>
2010技术应用计划
查看>>
Winform开发框架之权限管理系统改进的经验总结(3)-系统登录黑白名单的实现...
查看>>
JavaScript高级程序设计--对象,数组(栈方法,队列方法,重排序方法,迭代方法)...
查看>>
【转】 学习ios(必看经典)牛人40天精通iOS开发的学习方法【2015.12.2
查看>>
在 ASP.NET MVC 中使用异步控制器
查看>>
SQL语句的执行过程
查看>>
详解Linux中Load average负载
查看>>