WebSocket的用法——服务器主动给客户端推送数据

介绍

定义

WebSocket 是基于 TCP 的一种新的网络协议。它实现了浏览器与服务器全双工通信——浏览器和服务器只需要完成一次握手,两者之间就可以创建持久性的连接, 并进行双向数据传输。
(注:http1.1开始使用长连接,1.0默认使用短连接

HTTP协议和WebSocket协议对比

HTTP和WebSocket底层都是TCP连接

HTTP是短连接;HTTP通信是单向的,基于请求响应模式(方向:一定是客户端浏览器主动发请求,服务器才能接受请求并响应)


WebSocket是长连接(长连接不要刷新就能get到数据);WebSocket支持双向通信(注:首先是客户端浏览器发起请求,也就是握手,以便之后客户端浏览器能主动给服务器发送数据,服务器也能主动给客户端浏览器推送数据)

WebSocket的应用场景

视频弹幕;网页聊天;体育实况更新;股票基金报价实时更新(注:并不需要页面发请求来获取数据,而是服务器主动给客户端推送数据

步骤

直接使用websocket.html页面作为WebSocket客户端

(每刷新页面,就是new一个新的WebSocket,即握手成功,这个连接就建立好了)

<!DOCTYPE HTML>
<html>
<head>
    <meta charset="UTF-8">
    <title>WebSocket Demo</title>
</head>
<body>
    <input id="text" type="text" />
    <button onclick="send()">发送消息</button>
    <button onclick="closeWebSocket()">关闭连接</button>
    <div id="message">
    </div>
</body>
<script type="text/javascript">
    var websocket = null;
	//随机id
    var clientId = Math.random().toString(36).substr(2);

    //判断当前浏览器是否支持WebSocket
    if('WebSocket' in window){
   
        //连接WebSocket节点
        websocket = new WebSocket("ws://localhost:8080/ws/"+clientId);
    }
    else{
   
        alert('Not support websocket')
    }

    //连接发生错误的回调方法
    websocket.onerror <
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

୧⍤⃝�摩西摩西

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值