国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 微信小程式 小程式開發(fā) 微信小程式WebSocket協(xié)定說明及使用範(fàn)例分享

微信小程式WebSocket協(xié)定說明及使用範(fàn)例分享

May 10, 2018 pm 03:52 PM
微信小程式

本文講述微信小程式WebSocket協(xié)定說明及使用範(fàn)例分享,用範(fàn)例的方式,讓我們快速熟悉和用起來。

WebSocket是什麼(簡述)
微信的WebSocket介面和HTML5的WebSocket基本上一樣,是HTTP協(xié)定升級來的,做為一個新的Socket在B/S上使用,它實(shí)現(xiàn)了瀏覽器與伺服器全雙工通信。
因?yàn)檫@裡是做小程序,所以就不對WebSocket的底層和協(xié)議做過多的說明了,只是稍微介紹一下。想了解詳細(xì)的WebSocket可以參考如下:

WebSocket 協(xié)定

WebSocket與Ajax 的選擇

在WebSocket出來之前,實(shí)現(xiàn)即時通訊通常使用Ajax來實(shí)現(xiàn),而Ajax是透過即時的方式進(jìn)行資料獲取,輪詢就是在指定的時間間隔內(nèi),進(jìn)行HTTP 請求來獲取數(shù)據(jù),而這種方式會產(chǎn)生一些弊端,一方面產(chǎn)生過多的HTTP請求,佔(zhàn)用頻寬,增大伺服器的相應(yīng),浪費(fèi)資源,另一方面,因?yàn)椴皇敲總€請求都會有資料變化(就像聊天室),所以就會造成請求的使用率低。
而WebSocket正好能夠解決上面的弊端,WebSocket是客戶端與伺服器之前專門建立一條通道,請求也只請求一次,而且可以從同道中實(shí)時的獲取伺服器的數(shù)據(jù),所以當(dāng)應(yīng)用到實(shí)時的應(yīng)用上時, WebSocket是一個很不錯的選擇。

WebSocket協(xié)議名

WebSocket的連結(jié)不是以http或https開頭的,而是以ws和wss開頭的,這裡要注意一下。
實(shí)例:實(shí)時顯示交易信息

這裡類似於實(shí)時查看股票信息,這裡用到了圖表插件wxchart。

wxchart外掛位址:

基本上說的差不多了,正式開始。
新增stock頁面:
微信小程式WebSocket協(xié)定說明及使用範(fàn)例分享

將wxchart.js放入到pages/stock/中。
修改stock.wxml:
微信小程式WebSocket協(xié)定說明及使用範(fàn)例分享

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連接失?。?amp;#39;);
    })
  },
})



這裡的WebSocket位址是ws://localhost,連接埠是12345,連線成功後,向伺服器發(fā)送stock,然後伺服器向小程式提供數(shù)據(jù)資訊。
WebSocket的伺服器端我是用PHP寫的,這裡貼一下,大家可以參考一下:

<?php
include &#39;WebSocket.php&#39;;

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 == &#39;stock&#39;) {
                        $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(&#39;localhost&#39;, 12345);
$s -> run();

用PHP寫WebSocket稍微有些麻煩,懂Node.js的可用Node.js寫一下,Node.js寫後端的WebSocket很方便。

實(shí)例效果:

微信小程式WebSocket協(xié)定說明及使用範(fàn)例分享
微信WebSocketAPI參數(shù)說明

wx.connectSocket(OBJECT)

String是否String介面呼叫成功的回呼函數(shù)否
開發(fā)者伺服器介面位址,必須是wss 協(xié)議,且網(wǎng)域名稱必須是後臺配置的合法網(wǎng)域名稱 data Object
HTTP Header , header 中不能設(shè)定Referer method
預(yù)設(shè)是GET,有效值為: OPTIONS, GETS, GETS, GETp. success Function
fail Function
介面呼叫結(jié)束的回呼函數(shù)(呼叫成功、失敗都會執(zhí)行)

wx.onSocketOpen(CALLBACK)

監(jiān)聽WebSocket連線開啟事件。
wx.onSocketError(CALLBACK)

監(jiān)聽WebSocket錯誤。
wx.sendSocketMessage(OBJECT)

透過 WebSocket 連線傳送數(shù)據(jù),需要先 wx.connectSocket,並在 wx.onSocketOpen 回呼之後才能傳送。
[tr]成功的回呼函數(shù)

failFunction否介面呼叫失敗的回呼函數(shù)complete監(jiān)聽WebSocket接受到伺服器的訊息事件。 dataString/ArrayBuffer伺服器回傳的訊息關(guān)於localhost
wx.onSocketMessage(CALLBACK)
[tr] 參數(shù) 類型 說明[/tr]
wx.onSocketClose(CALLBACK) 監(jiān)聽WebSocket關(guān)閉。
這裡說明一下localhost,上述程式碼中我用到了localhost的本地請求,這裡只是佔(zhàn)位使用,在程式編寫中是不支援localhost本地請求的,這裡大家要注意一下。

以上是微信小程式WebSocket協(xié)定說明及使用範(fàn)例分享的詳細(xì)內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

閒魚微信小程式正式上線 閒魚微信小程式正式上線 Feb 10, 2024 pm 10:39 PM

閒魚官方微信小程式悄悄上線,在小程式中可以發(fā)布閒置與買家/賣家私訊交流、查看個人資料及訂單、搜尋物品等,有用好奇閒魚微信小程式叫什麼,現(xiàn)在快來看一下。閒魚微信小程式叫什麼答案:閒魚,閒置交易二手買賣估價回收。 1、在小程式中可以發(fā)布閒置、與買家/賣家私訊交流、查看個人資料及訂單、搜尋指定物品等功能;2、在小程式的頁面中有首頁、附近、發(fā)閒置、訊息、我的5項(xiàng)功能;3、想要使用的話必要要開通微信支付才可以購買;

實(shí)現(xiàn)微信小程式中的圖片濾鏡效果 實(shí)現(xiàn)微信小程式中的圖片濾鏡效果 Nov 21, 2023 pm 06:22 PM

實(shí)現(xiàn)微信小程式中的圖片濾鏡效果隨著社群媒體應(yīng)用程式的流行,人們越來越喜歡在照片中應(yīng)用濾鏡效果,以增強(qiáng)照片的藝術(shù)效果和吸引力。在微信小程式中也可以實(shí)現(xiàn)圖片濾鏡效果,為使用者提供更多有趣和創(chuàng)意的照片編輯功能。本文將介紹如何在微信小程式中實(shí)現(xiàn)圖片濾鏡效果,並提供具體的程式碼範(fàn)例。首先,我們需要在微信小程式中使用canvas元件來載入和編輯圖片。 canvas元件可以在頁面

實(shí)作微信小程式中的下拉式選單效果 實(shí)作微信小程式中的下拉式選單效果 Nov 21, 2023 pm 03:03 PM

實(shí)現(xiàn)微信小程式中的下拉式選單效果,需要具體程式碼範(fàn)例隨著行動互聯(lián)網(wǎng)的普及,微信小程式成為了網(wǎng)路開發(fā)的重要一環(huán),越來越多的人開始關(guān)注和使用微信小程式。微信小程式的開發(fā)相比傳統(tǒng)的APP開發(fā)更加簡單快捷,但也需要掌握一定的開發(fā)技巧。在微信小程式的開發(fā)中,下拉式選單是一個常見的UI元件,實(shí)現(xiàn)了更好的使用者操作體驗(yàn)。本文將詳細(xì)介紹如何在微信小程式中實(shí)現(xiàn)下拉式選單效果,並提供具

閒魚微信小程式叫什麼 閒魚微信小程式叫什麼 Feb 27, 2024 pm 01:11 PM

閒魚官方微信小程式已經(jīng)悄悄上線,它為用戶提供了一個便捷的平臺,讓你可以輕鬆地發(fā)布和交易閒置物品。在小程式中,你可以與買家或賣家進(jìn)行私訊交流,查看個人資料和訂單,以及搜尋你想要的物品。那麼閒魚在微信小程式中究竟叫什麼呢,這篇教學(xué)攻略將為您詳細(xì)介紹,想要了解的用戶們快來跟著本文繼續(xù)閱讀吧!閒魚微信小程式叫什麼答案:閒魚,閒置交易二手買賣估價回收。 1、在小程式中可以發(fā)布閒置、與買家/賣家私訊交流、查看個人資料及訂單、搜尋指定物品等功能;2、在小程式的頁面中有首頁、附近、發(fā)閒置、訊息、我的5項(xiàng)功能;3、

微信小程式實(shí)現(xiàn)圖片上傳功能 微信小程式實(shí)現(xiàn)圖片上傳功能 Nov 21, 2023 am 09:08 AM

微信小程式實(shí)現(xiàn)圖片上傳功能隨著行動網(wǎng)路的發(fā)展,微信小程式已經(jīng)成為了人們生活中不可或缺的一部分。微信小程式不僅提供了豐富的應(yīng)用場景,還支援開發(fā)者自訂功能,其中包括圖片上傳功能。本文將介紹如何在微信小程式中實(shí)作圖片上傳功能,並提供具體的程式碼範(fàn)例。一、前期準(zhǔn)備工作在開始編寫程式碼之前,我們需要先下載並安裝微信開發(fā)者工具,並註冊成為微信開發(fā)者。同時,也需要了解微信

使用微信小程式實(shí)現(xiàn)輪播圖切換效果 使用微信小程式實(shí)現(xiàn)輪播圖切換效果 Nov 21, 2023 pm 05:59 PM

使用微信小程式實(shí)現(xiàn)輪播圖切換效果微信小程式是一種輕量級的應(yīng)用程序,具有簡單、高效的開發(fā)和使用特點(diǎn)。在微信小程式中,實(shí)作輪播圖切換效果是常見的需求。本文將介紹如何使用微信小程式實(shí)現(xiàn)輪播圖切換效果,並給出具體的程式碼範(fàn)例。首先,在微信小程式的頁面檔案中,新增一個輪播圖元件。例如,可以使用&lt;swiper&gt;標(biāo)籤來實(shí)現(xiàn)輪播圖的切換效果。在該組件中,可以透過b

實(shí)現(xiàn)微信小程式中的圖片旋轉(zhuǎn)效果 實(shí)現(xiàn)微信小程式中的圖片旋轉(zhuǎn)效果 Nov 21, 2023 am 08:26 AM

實(shí)現(xiàn)微信小程式中的圖片旋轉(zhuǎn)效果,需要具體程式碼範(fàn)例微信小程式是一種輕量級的應(yīng)用程序,為用戶提供了豐富的功能和良好的用戶體驗(yàn)。在小程式中,開發(fā)者可以利用各種元件和API來實(shí)現(xiàn)各種效果。其中,圖片旋轉(zhuǎn)效果是一種常見的動畫效果,可以為小程式增添趣味性和視覺效果。在微信小程式中實(shí)作圖片旋轉(zhuǎn)效果,需要使用小程式提供的動畫API。以下是一個具體的程式碼範(fàn)例,展示如何在小程

實(shí)作微信小程式中的滑動刪除功能 實(shí)作微信小程式中的滑動刪除功能 Nov 21, 2023 pm 06:22 PM

實(shí)作微信小程式中的滑動刪除功能,需要具體程式碼範(fàn)例隨著微信小程式的流行,開發(fā)者在開發(fā)過程中經(jīng)常會遇到一些常見功能的實(shí)作問題。其中,滑動刪除功能是常見、常用的功能需求。本文將為大家詳細(xì)介紹如何在微信小程式中實(shí)現(xiàn)滑動刪除功能,並給出具體的程式碼範(fàn)例。一、需求分析在微信小程式中,滑動刪除功能的實(shí)作涉及以下要點(diǎn):列表展示:要顯示可滑動刪除的列表,每個列表項(xiàng)目需要包

See all articles