通过融云 WebSDK 简单了解 WebSocket

171 篇文章 0 订阅
120 篇文章 1 订阅

近期使用融云开发聊天页面, 通过抓包, 发现融云 SDK 使用 WebSocket 实现与服务端通讯, 由此简单了解下 WebSocket 的使用

需要 WebSocket 的原因:

一句话总结: HTTP 协议只能由客户端发起, 服务端响应. WebSocket 可服务端主动发起, 也可客户端发起. 能实现的场景更多、更复杂

相关资料如下:

融云开发文档: https://docs.rongcloud.cn/v4/

WebSocket Web API: https://developer.mozilla.org/zh-CN/docs/Web/API/WebSocket

WebSocket Node API: socket.iowsuWebSockets (任选其一)

融云抓包

测试地址: https://rongcloud.github.io/websdk-demo/api-test/

通过抓包可知, 融云链接 websocket 时还带了 appkey、token、SDK 版本信息

接下来实现一个简单地 客户端 + 服务端示例

Nodejs 服务端

此处示例使用 ws 模块

创建链接:

const Port = '2928';
const wss = new WebSocket.Server({ port: Port });
wss.on('connection', function (ws, event) {
  const url = event.url; // url 为客户端链接地址, 可拼接参数. 比如融云拼接了 appkey 等信息: ?appid=n19xxxxxx&token=xxxxxxxx

  /* 监听链接关闭 */
  ws.on('close', () => {
    // 此 ws 链接已断开. do something
  });
});

监听客户端消息:

const Port = '2928';
const wss = new WebSocket.Server({ port: Port });
wss.on('connection', function (ws, event) {
  ws.on('message', function (data) {
    console.log('data', data); // 收到客户端发送的数据 do something
  });
});

向客户端发送请求:

const Port = '2928';
const wss = new WebSocket.Server({ port: Port });
wss.on('connection', function (ws, event) {
  ws.send('some data');
});
Web 客户端

具体 API 可参考: WebSocket

建立链接:

const socket = new WebSocket('ws://localhost:2928');
socket.addEventListener('open', function (event) {
  // 链接成功, do something
});

监听服务端消息:

const socket = new WebSocket('ws://localhost:2928');
socket.addEventListener('message', function (event) {
  console.log('收到服务端发送的数据', event.data);
});

向服务端发送请求:

const socket = new WebSocket('ws://localhost:2928');
socket.addEventListener('open', function (event) {
  socket.send('some data'); // 链接后, 调用 send 发送
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值