IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> 微信小程序websocket正确姿势 -> 正文阅读

[网络协议]微信小程序websocket正确姿势

1.请求地址必须是ws://或wss://

var?wsurl?=?'wss://zsj.itdos.net/v1'

2.服务端websocket必须返回文件头protocol

小程序端请求会发送protocol,服务端必须取得这个再发回去?

go语言这样处理:https://studygolang.com/articles/22255?fr=sidebar

websocket包采用的是github.com/gorilla/websocket

    var upgrade = websocket.Upgrader{
        // cross origin domain
        CheckOrigin: func(r *http.Request) bool {   //这个是解决跨域问题
            return true
        },
        Subprotocols:[]string{s.Ctx.Input.Header("Sec-WebSocket-Protocol")},  
        //将获取的参数放进这个数组,问题解决
    }

3.小程序wss请求带上sessionid,才能进行用户判断

?https://blog.csdn.net/zhangheng028/article/details/50352564

4.上小程序代码

// 计算
  formSubmit: function (e) {
    var that = this;
    if (that.data.NumberError != null) {
      wx.showToast({
        title: "输入存在错误",
        icon: 'none',
        duration: 2000
      });
      return;
    }
    //清除计时器  即清除setInter
    clearInterval(that.data.setInter)
    that.setData({
      canDownload: false,
      num: 0,
      canCalculate: false
    })
    //将计时器赋值给setInter
    that.data.setInter = setInterval(
      function () {
        var numVal = that.data.num + 1;
        that.setData({
          num: numVal
        });
      }, 1000);
    var sessionId = wx.getStorageSync('sessionId')
    var apiUrl = config.wsurl + '/mathcad/postwxmath2/' + that.data.id+'?hotqinsessionid='+sessionId;

    var obj = {};
    obj.message = new Date().toLocaleString();
    obj.templeid = that.data.id
    obj.inputdata = e.detail.value
    obj = JSON.stringify(obj); //将JSON对象转化为JSON字符

    let SocketTask = wx.connectSocket({
      url: apiUrl, //'wss://example.qq.com',
      header: {
        'content-type': 'application/json'
      },
      protocols: ['protocol1'],
      method: "GET",
      success: function (res) {
        console.log(res)
      }
    })

    SocketTask.onOpen(function (res) {
      // console.log('WebSocket连接已打开!')
      SocketTask.send({
        data: obj, //postData,
        success: function () {
          console.log('发送成功')
          // console.log(obj)
        },
        fail: function (err) {
          console.log('发送失败')
          console.log(err)
          // 停止计时器
          clearInterval(that.data.setInter)
        }
      })
    })

    SocketTask.onClose(function (res) {
      console.log('WebSocket连接已关闭!')
    })

    SocketTask.onMessage(function (res) {
      // console.log('接收到的消息:' + res.data)
      var msg = JSON.parse(res.data);
      var tmpArr = that.data.wsMessage + msg.message + '\n';
      that.setData({
        wsMessage: tmpArr
      })
      if (msg.info == "ERROR") {
        //清除计时器  即清除setInter
        clearInterval(that.data.setInter)
        that.setData({
          canCalculate: true
        })
        wx.showToast({
          title: msg.data.info,
          icon: 'none',
          duration: 2000
        })
      } else if (msg.info == "SUCCESS") {
        // 停止计时器
        clearInterval(that.data.setInter)
        that.setData({
          mathcaloutput: msg.data,
          canDownload: true,
          canCalculate: true,
          pdflink: msg.pdflink
        })
      }
    })
  },

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-08-10 13:47:35  更:2021-08-10 13:50:14 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/28 6:16:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计