微信小程序 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代码:

?
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({
    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写的,这里贴一下,大家可以参考一下:

?
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代码:代码下载

微信WebSocketAPI参数说明wx.connectSocket(OBJECT)

 

参数类型必填说明
urlString开发者服务器接口地址,必须是 wss 协议,且域名必须是后台配置的合法域名
dataObject请求的数据
headerObjectHTTP Header , header 中不能设置 Referer
methodString默认是GET,有效值为: OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT
successFunction接口调用成功的回调函数
failFunction接口调用失败的回调函数
completeFunction接口调用结束的回调函数(调用成功、失败都会执行)

 

wx.onSocketOpen(CALLBACK)

监听WebSocket连接打开事件。

wx.onSocketError(CALLBACK)

监听WebSocket错误。

wx.sendSocketMessage(OBJECT)

通过 WebSocket 连接发送数据,需要先 wx.connectSocket,并在 wx.onSocketOpen 回调之后才能发送。

 

 

 

参数类型必填说明
dataString/ArrayBuffer需要发送的内容
successFunction接口调用成功的回调函数
failFunction接口调用失败的回调函数
completeFunction接口调用结束的回调函数(调用成功、失败都会执行)

 

监听WebSocket接受到服务器的消息事件。

 

 

 

参数类型说明
dataString/ArrayBuffer服务器返回的消息

 

关闭WebSocket连接。

wx.onSocketClose(CALLBACK)

监听WebSocket关闭。

关于localhost

这里说明一下localhost,上述代码中我用到了localhost的本地请求,这里只是占位使用,在程序编写中是不支持localhost本地请求的,这里大家要注意一下。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

转载于:https://www.cnblogs.com/yingsu/p/6894677.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值