微信小程序 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
代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
// pages/stock/stock.js //加载插件 var wxCharts = require( \'wxcharts.js\' ); Page({ data: {}, onLoad: function (options) { //建立连接 wx.connectSocket({ }) //连接成功 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写的,这里贴一下,大家可以参考一下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
<?php include \'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
回调之后才能发送。
参数 | 类型 | 必填 | 说明 |
---|---|---|---|
data | String/ArrayBuffer | 是 | 需要发送的内容 |
success | Function | 否 | 接口调用成功的回调函数 |
fail | Function | 否 | 接口调用失败的回调函数 |
complete | Function | 否 | 接口调用结束的回调函数(调用成功、失败都会执行) |
监听WebSocket接受到服务器的消息事件。
参数 | 类型 | 说明 |
---|---|---|
data | String/ArrayBuffer | 服务器返回的消息 |
关闭WebSocket连接。
wx.onSocketClose(CALLBACK)
监听WebSocket关闭。
关于localhost
这里说明一下localhost
,上述代码中我用到了localhost
的本地请求,这里只是占位使用,在程序编写中是不支持localhost
本地请求的,这里大家要注意一下。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
请发表评论