微信小程序 WebSocket
实例效果:
今天主要说一下微信的WebSocket
接口以及在小程序中的使用。
WebSocket
是什么(简述)
微信的WebSocket
接口和HTML5的WebSocket
基本一样,是HTTP协议升级来的,做为一个新的Socket
在B/S上使用,它实现了浏览器与服务器全双工通信。
因为这里是做小程序,所以就不对WebSocket
的底层和协议做过多的说明了,只是稍微介绍一下。想了解详细的WebSocket
可以参考如下:WebSocket 协议
WebSocket与Ajax 的选择
在WebSocket
出来之前,实现即时通讯通常使用Ajax
来实现,而Ajax
是通过轮询的方式进行实时数据的获取,轮询就是在指定的时间间隔内,进行HTTP 请求来获取数据,而这种方式会产生一些弊端,一方面产生过多的HTTP请求,占用带宽,增大服务器的相应,浪费资源,另一方面,因为不是每一次请求都会有数据变化(就像聊天室),所以就会造成请求的利用率低。
而WebSocket
正好能够解决上面的弊端,WebSocket
是客户端与服务器之前专门建立一条通道,请求也只请求一次,而且可以从同道中实时的获取服务器的数据,所以当应用到实时的应用上时,WebSocket
是一个很不错的选择。
WebSocket
协议名
WebSocket
的链接不是以http
或https
开头的,而是以ws
和wss
开头的,这里需要注意一下。
实例:实时显示交易信息
这里类似于实时查看股票信息,这里用到了图表插件wxchart:wxchart插件地址:插件下载
基本说的差不多了,正式开始。
将wxchart.js
放入到pages/stock/
中。
修改stock.wxml
:
stock.js
代码:
Page({
data: {},onLoad: function (options) {
//建立连接
wx.connectSocket({
url: "ws://localhost:12345",})
//连接成功
wx.onSocketOpen(function() {
wx.sendSocketMessage({
data: 'stock',})
})
//接收数据
wx.onSocketMessage(function(data) {
var objData = JSON.parse(data.data);
console.log(data);
new wxCharts({
canvasId: 'lineCanvas',//指定canvas的id
animation: false,type: 'line',//类型是线形图
categories: ['2012','2013','2014','2015','2016','2017'],series: [{
name: '交易量',data: objData,//websocket接收到的数据
format: function (val) {
if (typeof val == "string") {
val = parseFloat(val);
}
return val.toFixed(2) + '万元';
}
},],yAxis: {
title: '交易金额 (万元)',format: function (val) {
return val.toFixed(2);
},min: 0
},width: 320,height: 200
});
})
//连接失败
wx.onSocketError(function() {
console.log('websocket连接失败!');
})
},})
这里WebSocket
的地址是ws://localhost
,端口是12345
,连接成功后,向服务器发送stock
,然后服务器向小程序提供数据信息。
WebSocket
的服务器端我是用PHP写的,这里贴一下,大家可以参考一下:
public function run(){
while(true){
$socketArr = $this->sockets;
$write = NULL;
$except = NULL;
socket_select($socketArr,$write,$except,NULL);
foreach ($socketArr as $socket){
if ($socket == $this->master){
$client = socket_accept($this->master);
if ($client < 0){
$this->log("socket_accept() Failed");
continue;
}else{
$this->connect($client);
}
}
else{
$this->log("----------New Frame Start-------");
$bytes = @socket_recv($socket,$buffer,2048,0);
if ($bytes == 0){
$this->disconnect($socket);
}else{
$user = $this->getUserBySocket($socket);
if (!$user->handshake){
$this->doHandShake($user,$buffer);
}else{
$buffer = $this->unwrap($user->socket,$buffer);
//请求为stock时,向通道内推送数据
if ($buffer == 'stock') {
$arr = array();
//模拟数据
for ($i=0; $i < 6; $i++) {
$arr[] = rand(1,100) / 100;
}
$this->send($user->socket,json_encode($arr));
}
}
}
}
}
}
}
}
$s = new WebSocket2('localhost',12345);
$s -> run();
用PHP写WebSocket
稍微有些麻烦,懂Node.js的可用Node.js写一下,Node.js写后端的WebSocket
很方便。
微信WebSocket
API参数说明wx.connectSocket(OBJECT)
类型 | 必填 | 说明 |
---|---|---|
wx.onSocketOpen(CALLBACK)
监听WebSocket连接打开事件。
wx.onSocketError(CALLBACK)
监听WebSocket错误。
wx.sendSocketMessage(OBJECT)
通过 WebSocket
连接发送数据,需要先 wx.connectSocket
,并在 wx.onSocketOpen
回调之后才能发送。
类型 | 必填 | 说明 |
---|---|---|
监听WebSocket接受到服务器的消息事件。
类型 | 说明 |
---|---|
关闭WebSocket连接。
wx.onSocketClose(CALLBACK)
监听WebSocket关闭。
关于localhost
这里说明一下localhost
,上述代码中我用到了localhost
的本地请求,这里只是占位使用,在程序编写中是不支持localhost
本地请求的,这里大家要注意一下。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:https://www.f2er.com/weapp/42256.html