微信小程序,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 的链接不是以http 或https 开头的,而是以ws 和wss 开头的,这里需要注意一下。
实例:实时显示交易信息 这里类似于实时查看股票信息,这里用到了图表插件wxchart:wxchart插件地址:插件下载 基本说的差不多了,正式开始。 添加stock 页面: 
将wxchart.js 放入到pages/stock/ 中。 修改stock.wxml : 
stock.js 代码:
// pages/stock/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写的,这里贴一下,大家可以参考一下:
<?phpinclude 'WebSocket.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(); 用PHP写WebSocket 稍微有些麻烦,懂Node.js的可用Node.js写一下,Node.js写后端的WebSocket 很方便。 上面用到的WebSocket.php代码:代码下载 微信WebSocket API参数说明wx.connectSocket(OBJECT) 参数 | 类型 | 必填 | 说明 | url | String | 是 | 开发者服务器接口地址,必须是 wss 协议,且域名必须是后台配置的合法域名 | data | Object | 否 | 请求的数据 | header | Object | 否 | HTTP Header , header 中不能设置 Referer | method | String | 否 | 默认是GET,有效值为: OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT | success | Function | 否 | 接口调用成功的回调函数 | fail | Function | 否 | 接口调用失败的回调函数 | complete | Function | 否 | 接口调用结束的回调函数(调用成功、失败都会执行) | wx.onSocketOpen(CALLBACK)
监听WebSocket连接打开事件。 wx.onSocketError(CALLBACK)
监听WebSocket错误。 wx.sendSocketMessage(OBJECT)
通过 WebSocket 连接发送数据,需要先 wx.connectSocket ,并在 wx.onSocketOpen 回调之后才能发送。 |