当前位置: 首页 > news >正文

做网站用啥软件好如何把网站建设好

做网站用啥软件好,如何把网站建设好,佛山网站建设外包,网站h标签浏览器和服务器之间的通信更便利,比http的轮询等效率提高很多, WebSocket并不是权限的协议,而是利用http协议来建立连接 websocket必须由浏览器发起请求,协议是一个标准的http请求,格式如下 GET ws://example.com:3…

浏览器和服务器之间的通信更便利,比http的轮询等效率提高很多,

WebSocket并不是权限的协议,而是利用http协议来建立连接

websocket必须由浏览器发起请求,协议是一个标准的http请求,格式如下

GET ws://example.com:3000/chat HTTP/1.1
Host: example.com
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Key: dGhlIHNhbXBsZSBub25jZQ==
Sec-WebSocket-Version: 13
Origin: https://example.com:3000

关键字段解释:‌

‌Upgrade: websocket‌:表示客户端希望升级到 WebSocket 协议。
‌Connection: Upgrade‌:确认协议升级。
‌Sec-WebSocket-Key‌:一个 Base64 编码的随机值(16字节),用于握手验证。
‌Sec-WebSocket-Version‌:指定 WebSocket 协议版本(通常为 13)。
‌Origin‌(可选):用于跨域控制,服务器可据此决定是否允许连接。

服务器响应(Server Handshake Response)‌
服务器返回 ‌HTTP 101 Switching Protocols‌ 状态码,确认协议升级:

Copy Code
HTTP/1.1 101 Switching Protocols
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Accept: s3pPLMBiTxaQ9kYGzzhZRbK+xOo=



‌关键字段解释:‌

‌Sec-WebSocket-Accept‌:服务器将客户端的 Sec-WebSocket-Key 与固定 GUID 258EAFA5-E914-47DA-95CA-C5AB0DC85B11 拼接后,进行 SHA-1 哈希并 Base64 编码,返回此值供客户端验证。

握手成功后,通信将脱离 HTTP,转为基于帧的 WebSocket 协议。

为什么websocket连接可以实现双工通信,而http不可以呢?实际上上,http是建立在tcp之上的,tcp本身就实现了双工通信,但http协议的请求--应答机制限制了全双工通信。websocket连接建立以后,其实只是简单规定了一下:咱们接下来的通信就不使用http了,咱们直接互发数据吧。

安全的websocket连接机制和https类似,首先,浏览器用wss://创建websocket连接,会先通过https创建安全连接,然后,该https升级为websocket连接,底层通信仍然走的是安全的SSL/TLS

uniapp使用websocket,需实现心跳‌:防止因网络空闲导致连接断开

let timer;
const socketTask = uni.connectSocket({ url: 'wss://example.com' });socketTask.onOpen(() => {timer = setInterval(() => {socketTask.send({ data: 'ping' });}, 30000);
});socketTask.onClose(() => {clearInterval(timer);
});

 Node.js 服务端设置 WebSocket 跨域:(关键在于 ‌握手阶段对 Origin 头的验证)

const WebSocket = require('ws');// 允许的 Origin 白名单
const allowedOrigins = ['https://your-frontend-domain.com','http://localhost:3000'
];const wss = new WebSocket.Server({port: 8080,verifyClient: (info) => {const origin = info.origin || info.req.headers.origin;if (!allowedOrigins.includes(origin)) {console.log(`拒绝来自 ${origin} 的跨域请求`);return false; // 阻止握手}return true; // 允许连接}
});wss.on('connection', (ws) => {console.log('客户端已连接');
});

http://www.dtcms.com/a/400774.html

相关文章:

  • Day08_单片机-ADC和DMA
  • Go 1.25 新特性深度解析:json/v2 重新定义 Go 的 JSON 处理
  • 企业网站建设前言成品短视频软件大全下载手机版
  • 建站公司 转型经验关联词有哪些四年级
  • 北京州网站建设公司个人网页设计图片背景图
  • 茂名网站制作网页自己做的美食分享到网站
  • 厦门市建设执业资格管理中心网站电子商务平台系统
  • 阿里云虚拟主机可以做两个网站哈尔滨网络推广经理招聘
  • 学而思的网站哪里做的aws 搭建wordpress
  • js做网站预览效果wordpress设置主从库
  • 杨浦企业网站建设天河建设网站多少钱
  • 网站开发工程师特点深圳网站设计报价
  • 个人网站建设规划凯里网站设计公司
  • 社交做的最好的网站网页
  • 个人网站页脚设计wordpress系统加速优化
  • 怎么做网站有利于收录珠海网站备案
  • 花都区水务建设管理中心官方网站安防监控网站模板
  • 学做网站论坛vip账号如何查网站死链
  • 上海专业网站推广公司万联芯城网站建设
  • 手机网站一定要与pc网站一样淘宝客网站怎么批量采集淘宝商品方维采集淘宝数据思路
  • 网站建设与运维山东省建设厅执业注册中心网站
  • 网站开发课程的建议网站建设优化开发公司哪家好
  • 做微博网站好不好用php做电商网站
  • 网站建设会计处理查网站权重
  • 网站做app的软件叫什么网站建设模式怎么写
  • 乐清做网站培训自己做网站详细步骤
  • 怎么建设网站网页前端做网站需要学什么软件
  • wordpress设置网站地图网站元素优化 移动站
  • 网站屏蔽省份做视频网站要什么软件
  • 哪家网站做推广好淄博网站建设公司三农