源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

微信小程序 WebSocket详解及应用

  • 时间:2021-09-03 15:32 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:微信小程序 WebSocket详解及应用
[b]微信小程序 WebSocket[/b] 实例效果: [img]http://files.jb51.net/file_images/article/201701/2017121102604195.gif?2017021102639[/img] 今天主要说一下微信的[code]WebSocket[/code]接口以及在小程序中的使用。 [code]WebSocket[/code]是什么(简述) 微信的[code]WebSocket[/code]接口和HTML5的[code]WebSocket[/code]基本一样,是HTTP协议升级来的,做为一个新的[code]Socket[/code]在B/S上使用,它实现了浏览器与服务器全双工通信。 因为这里是做小程序,所以就不对[code]WebSocket[/code]的底层和协议做过多的说明了,只是稍微介绍一下。想了解详细的[code]WebSocket[/code]可以参考如下:WebSocket 协议 [b]WebSocket与Ajax 的选择[/b] 在[code]WebSocket[/code]出来之前,实现即时通讯通常使用[code]Ajax[/code]来实现,而[code]Ajax[/code]是通过轮询的方式进行实时数据的获取,轮询就是在指定的时间间隔内,进行HTTP 请求来获取数据,而这种方式会产生一些弊端,一方面产生过多的HTTP请求,占用带宽,增大服务器的相应,浪费资源,另一方面,因为不是每一次请求都会有数据变化(就像聊天室),所以就会造成请求的利用率低。 而[code]WebSocket[/code]正好能够解决上面的弊端,[code]WebSocket[/code]是客户端与服务器之前专门建立一条通道,请求也只请求一次,而且可以从同道中实时的获取服务器的数据,所以当应用到实时的应用上时,[code]WebSocket[/code]是一个很不错的选择。 [code]WebSocket[/code]协议名 [code]WebSocket[/code]的链接不是以[code]http[/code]或[code]https[/code]开头的,而是以[code]ws[/code]和[code]wss[/code]开头的,这里需要注意一下。 实例:实时显示交易信息 这里类似于实时查看股票信息,这里用到了图表插件wxchart:wxchart插件地址:插件下载 基本说的差不多了,正式开始。 添加[code]stock[/code]页面: [img]http://files.jb51.net/file_images/article/201701/201701211014206.jpg[/img] 将[code]wxchart.js[/code]放入到[code]pages/stock/[/code]中。 修改[code]stock.wxml[/code]: [img]http://files.jb51.net/file_images/article/201701/201701211014207.jpg[/img] [code]stock.js[/code]代码:
// 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连接失败!');
  })
 },
})
这里[code]WebSocket[/code]的地址是[code]ws://localhost[/code],端口是[code]12345[/code],连接成功后,向服务器发送[code]stock[/code],然后服务器向小程序提供数据信息。 [code]WebSocket[/code]的服务器端我是用PHP写的,这里贴一下,大家可以参考一下:
<?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写[code]WebSocket[/code]稍微有些麻烦,懂Node.js的可用Node.js写一下,Node.js写后端的[code]WebSocket[/code]很方便。 上面用到的WebSocket.php代码:代码下载 微信[code]WebSocket[/code]API参数说明[code]wx.connectSocket(OBJECT)[/code]
参数 类型 必填 说明
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 接口调用结束的回调函数(调用成功、失败都会执行)
[code]wx.onSocketOpen(CALLBACK)[/code] 监听WebSocket连接打开事件。 [code]wx.onSocketError(CALLBACK)[/code] 监听WebSocket错误。 [code]wx.sendSocketMessage(OBJECT)[/code] 通过 [code]WebSocket[/code] 连接发送数据,需要先 [code]wx.connectSocket[/code],并在 [code]wx.onSocketOpen[/code] 回调之后才能发送。
参数 类型 必填 说明
data String/ArrayBuffer 需要发送的内容
success Function 接口调用成功的回调函数
fail Function 接口调用失败的回调函数
complete Function 接口调用结束的回调函数(调用成功、失败都会执行)
监听WebSocket接受到服务器的消息事件。
参数 类型 说明
data String/ArrayBuffer 服务器返回的消息
关闭WebSocket连接。 [code]wx.onSocketClose(CALLBACK)[/code] 监听WebSocket关闭。 关于[code]localhost[/code] 这里说明一下[code]localhost[/code],上述代码中我用到了[code]localhost[/code]的本地请求,这里只是占位使用,在程序编写中是不支持[code]localhost[/code]本地请求的,这里大家要注意一下。 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部