微信小程序 WebSocket详解及应用

前端之家收集整理的这篇文章主要介绍了微信小程序 WebSocket详解及应用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

微信小程序 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链接不是以httphttps开头的,而是以wswss开头的,这里需要注意一下。

实例:实时显示交易信息

这里类似于实时查看股票信息,这里用到了图表插件wxchart:wxchart插件地址:插件下载

基本说的差不多了,正式开始。

添加stock页面

wxchart.js放入到pages/stock/中。

修改stock.wxml

stock.js代码

插件 var wxCharts = require('wxcharts.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写的,这里贴一下,大家可以参考一下:

PHP;"> class WebSocket2 extends WebSocket{
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();

PHPWebSocket稍微有些麻烦,懂Node.js的可用Node.js写一下,Node.js写后端的WebSocket很方便。

上面用到的WebSocket.PHP代码代码下载

微信WebSocketAPI参数说明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

猜你在找的微信小程序相关文章