• 微信小程序 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
         },
          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)

    参数类型必填说明
    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本地请求的,这里大家要注意一下。

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

  • 相关阅读:
    台湾9大知名开源社区
    使用SignalR打造消息总线
    ENode 2.0
    Wireshark基本介绍和学习TCP三次握手 专题
    linux tomcat 的安装
    linux 之静默安装oracle
    什么是全栈呢(转)
    Android开发自学笔记(基于Android Studio1.3.1)—1.环境搭建(转)
    hdu 4919 Exclusive or
    D
  • 原文地址:https://www.cnblogs.com/yingsu/p/6894677.html
Copyright © 2020-2023  润新知