微信小程序 WebSocket 协议说明与使用示例详细解析

why 10 2024-09-25

本文讲述微信小程序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页面:
image.png

将wxchart.js放入到pages/stock/中。
修改stock.wxml:
image.png

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

          },

          width: 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 &#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时,向通道内推送数据

                    if ($buffer == &#39;stock&#39;) {

                        $arr = array();

 

                        //模拟数据

                        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很方便。

实例效果:

image.png

微信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本地请求的,这里大家要注意一下。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:微信小程序实现动态控制 switch 开关开和闭示例展示
下一篇:微信小程序获取与解密微信步数获取当日数据方法分享
相关文章

 发表评论

暂时没有评论,来抢沙发吧~