首页 > 热点 > 微信 > 正文

微信小程序webSocket的使用方法

2024-07-22 01:19:22
字体:
来源:转载
供稿:网友

博客简介

本篇博客介绍微信小程序中webSocket的使用方法,以及如何用局部网络建立webSocket连接,进行客户端与服务器之间的对话:

webSocket简介 微信小程序端API调用 服务器端使用nodejs配置 演示websocket

webSocket简介

WebSocket 是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在 WebSocket API 中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。在 WebSocket API 中,浏览器和服务器只需要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送。

现在,很多网站为了实现推送技术,所用的技术都是 Ajax 轮询。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP请求,然后由服务器返回最新的数据给客户端的浏览器。这种传统的模式带来很明显的缺点,即浏览器需要不断的向服务器发出请求,然而HTTP请求可能包含较长的头部,其中真正有效的数据可能只是很小的一部分,显然这样会浪费很多的带宽等资源。HTML5 定义的 WebSocket 协议,能更好的节省服务器资源和带宽,并且能够更实时地进行通讯。

微信小程序端API调用

微信小程序端需要做的配置有:

获取局部网络的地址 SocketTask wx.connectSocket创建一个 WebSocket 连接。 wx.onSocketOpen(function callback)监听 WebSocket 连接打开事件 wx.sendSocketMessage(Object object) 连接发送数据。 wx.onSocketMessage(function callback)监听 WebSocket 接受到服务器的消息事件

(1)获取局部网络的地址IP

获取局部网络的IP十分简单,打开设置,进入网络,点击WiFi属性,在IPv4右侧就能看见IP地址然后,在IP的前面加上ws://尾部加上3001得到可用的IP:
例如:

ws://199.213.7.102:3001

(2)建立客户端和服务器的链接,并且发送消息,监听服务器回发消息

在wxml部分设置一个按钮,用来获取信息亲切发送消息:

WXML:

<input type="tex" bindchange="sendMessage" class="text" placeholder="请输入消息"></input>

JS部分建立客户端和服务器的链接,并且发送消息,监听服务器回发消息:

//本地服务器地址var wsApi = "ws://199.213.7.102:3001";var socketOpen==false; sendMessage:function(e) {  var msg=e.detail.value;   if (socketOpen) {    console.log(msg);    //向服务器发送消息    wx.sendSocketMessage({     data: msg    })  } }, onLoad: function (options) {  //建立连接   wx.connectSocket({    url: wsApi,    header: {     'content-type': 'application/json'    },    //method:"GET",    protocols: ['protocol1'],    success: function () {     console.log("客户端连接成功!");     wx.onSocketOpen(function(){      console.log('webSocket已打开!');      socketOpen=true;      wx.onSocketMessage(function(msg){        console.log(msg);      })     })    }   }) },            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表