亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

微信小程序 WebSocket詳解及應(yīng)用

 更新時間:2017年01月21日 10:32:05   投稿:lqh  
這篇文章主要介紹了微信小程序 WebSocket詳解及應(yīng)用的相關(guān)資料,需要的朋友可以參考下

微信小程序 WebSocket

實(shí)例效果:

今天主要說一下微信的WebSocket接口以及在小程序中的使用。

WebSocket是什么(簡述)

微信的WebSocket接口和HTML5的WebSocket基本一樣,是HTTP協(xié)議升級來的,做為一個新的Socket在B/S上使用,它實(shí)現(xiàn)了瀏覽器與服務(wù)器全雙工通信。

因?yàn)檫@里是做小程序,所以就不對WebSocket的底層和協(xié)議做過多的說明了,只是稍微介紹一下。想了解詳細(xì)的WebSocket可以參考如下:WebSocket 協(xié)議

WebSocket與Ajax 的選擇

WebSocket出來之前,實(shí)現(xiàn)即時通訊通常使用Ajax來實(shí)現(xiàn),而Ajax是通過輪詢的方式進(jìn)行實(shí)時數(shù)據(jù)的獲取,輪詢就是在指定的時間間隔內(nèi),進(jìn)行HTTP 請求來獲取數(shù)據(jù),而這種方式會產(chǎn)生一些弊端,一方面產(chǎn)生過多的HTTP請求,占用帶寬,增大服務(wù)器的相應(yīng),浪費(fèi)資源,另一方面,因?yàn)椴皇敲恳淮握埱蠖紩袛?shù)據(jù)變化(就像聊天室),所以就會造成請求的利用率低。

WebSocket正好能夠解決上面的弊端,WebSocket是客戶端與服務(wù)器之前專門建立一條通道,請求也只請求一次,而且可以從同道中實(shí)時的獲取服務(wù)器的數(shù)據(jù),所以當(dāng)應(yīng)用到實(shí)時的應(yīng)用上時,WebSocket是一個很不錯的選擇。

WebSocket協(xié)議名

WebSocket的鏈接不是以httphttps開頭的,而是以wswss開頭的,這里需要注意一下。

實(shí)例:實(shí)時顯示交易信息

這里類似于實(shí)時查看股票信息,這里用到了圖表插件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',
   })
  })

  //接收數(shù)據(jù)
  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接收到的數(shù)據(jù)
      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,連接成功后,向服務(wù)器發(fā)送stock,然后服務(wù)器向小程序提供數(shù)據(jù)信息。

WebSocket的服務(wù)器端我是用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時,向通道內(nèi)推送數(shù)據(jù)
          if ($buffer == 'stock') {
            $arr = array();

            //模擬數(shù)據(jù)
            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參數(shù)說明wx.connectSocket(OBJECT)

參數(shù) 類型 必填 說明
url String 開發(fā)者服務(wù)器接口地址,必須是 wss 協(xié)議,且域名必須是后臺配置的合法域名
data Object 請求的數(shù)據(jù)
header Object HTTP Header , header 中不能設(shè)置 Referer
method String 默認(rèn)是GET,有效值為: OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT
success Function 接口調(diào)用成功的回調(diào)函數(shù)
fail Function 接口調(diào)用失敗的回調(diào)函數(shù)
complete Function 接口調(diào)用結(jié)束的回調(diào)函數(shù)(調(diào)用成功、失敗都會執(zhí)行)

wx.onSocketOpen(CALLBACK)

監(jiān)聽WebSocket連接打開事件。

wx.onSocketError(CALLBACK)

監(jiān)聽WebSocket錯誤。

wx.sendSocketMessage(OBJECT)

通過 WebSocket 連接發(fā)送數(shù)據(jù),需要先 wx.connectSocket,并在 wx.onSocketOpen 回調(diào)之后才能發(fā)送。

參數(shù) 類型 必填 說明
data String/ArrayBuffer 需要發(fā)送的內(nèi)容
success Function 接口調(diào)用成功的回調(diào)函數(shù)
fail Function 接口調(diào)用失敗的回調(diào)函數(shù)
complete Function 接口調(diào)用結(jié)束的回調(diào)函數(shù)(調(diào)用成功、失敗都會執(zhí)行)

監(jiān)聽WebSocket接受到服務(wù)器的消息事件。

參數(shù) 類型 說明
data String/ArrayBuffer 服務(wù)器返回的消息

關(guān)閉WebSocket連接。

wx.onSocketClose(CALLBACK)

監(jiān)聽WebSocket關(guān)閉。

關(guān)于localhost

這里說明一下localhost,上述代碼中我用到了localhost的本地請求,這里只是占位使用,在程序編寫中是不支持localhost本地請求的,這里大家要注意一下。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

最新評論