91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信小程序WebSocket協議是什么

發布時間:2021-03-01 13:45:44 來源:億速云 閱讀:308 作者:小新 欄目:移動開發

這篇文章主要介紹微信小程序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頁面:
微信小程序WebSocket協議是什么

將wxchart.js放入到pages/stock/中。
修改stock.wxml:
微信小程序WebSocket協議是什么

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',
      })
    })

    //接收數據
    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寫的,這里貼一下,大家可以參考一下:

<?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協議是什么
微信WebSocketAPI參數說明

wx.connectSocket(OBJECT)

[tr] 參數 類型 必填 說明[/tr]

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 回調之后才能發送。
[tr] 參數 類型 必填 說明[/tr]

dataString/ArrayBuffer需要發送的內容
successFunction接口調用成功的回調函數
failFunction接口調用失敗的回調函數
completeFunction接口調用結束的回調函數(調用成功、失敗都會執行)

wx.onSocketMessage(CALLBACK)

監聽WebSocket接受到服務器的消息事件。
[tr] 參數 類型 說明[/tr]

dataString/ArrayBuffer服務器返回的消息

wx.closeSocket()
關閉WebSocket連接。
wx.onSocketClose(CALLBACK)
監聽WebSocket關閉。
關于localhost
這里說明一下localhost,上述代碼中我用到了localhost的本地請求,這里只是占位使用,在程序編寫中是不支持localhost本地請求的,這里大家要注意一下。

以上是“微信小程序WebSocket協議是什么”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武夷山市| 新乡市| 益阳市| 迭部县| 安西县| 沭阳县| 荣昌县| 襄樊市| 赣榆县| 乌鲁木齐县| 龙川县| 怀仁县| 九寨沟县| 临海市| 蛟河市| 梧州市| 江阴市| 德江县| 馆陶县| 宁阳县| 札达县| 五原县| 海林市| 平舆县| 大余县| 贵港市| 青州市| 从化市| 上栗县| 四川省| 济宁市| 小金县| 晴隆县| 南平市| 磐石市| 和田市| 玉溪市| 长海县| 日喀则市| 即墨市| 永昌县|