微信小程序websocket
微信小程序websocket
微信小程序带有websocket可以提供使用,但是官方文档写的东西很少,而且小程序后台能力弱这一点也是十分的坑爹,这就导致了socket长连接一切后台就会出现断开的情况,并且难受的是.这个时候你重新调用链接函数也会链接不上,可能直接影响到你的业务逻辑
解决方法就是手动关闭和开启链接,不要让链接在程序切后台的时候被关掉,代码如下↓
- onHide监听程序进入后台的时候,手动关闭链接
onHide: function() {
var that = this;
console.log('程序进入了后台');
that.closeSocket();
}
- onShow监听程序进入后台的时候,手动开启链接
onShow: function() {
var that = this;
that.connectSocket();
}
- connectSocket函数
/**
* 链接会话,
* 每间隔一秒链接一次,知道链接成功后停止链接
*/
connectSocket() {
var that = this;
var wss_linker = setInterval(function() {
if (that.globalData.user) {
that.globalData.socketTask = wx.connectSocket({
url: that.globalData.socket_url + that.globalData.user.userId,
fail: function(res) {
wx.showModal({
title: '提示',
content: 'socket链接异常,请删除程序重试',
})
}
})
//监听链接开启
that.globalData.socketTask.onOpen(function(res) {
that.globalData.isConnect = true;
var keep_msg = "keep_connect";
that.globalData.keepConnectInterval = setInterval(function() {
wx.sendSocketMessage({
data: keep_msg,
})
console.log(keep_msg)
if (JSON.stringify(that.globalData.newMsg) == "{}") {
that.globalData.have_new_msg = false;
}
}, 1000)
//获取离线消息
that.get_old_msg(res => {
// 获取在线消息
that.globalData.socketTask.onMessage(function(res) {
var storage_msg = [];
var msg_obj = JSON.parse(res.data);
if (msg_obj.code && msg_obj.code == -1) {
wx.showModal({
title: '发送通知',
content: msg_obj.msg,
})
// that.globalData.flag=true;
} else {
wx.showToast({
title: 'You got a msg'
})
// 处理时间
that.format_date(msg_obj.chatTime, res => {
msg_obj.chatTime = res
var chatRequestUserId = msg_obj.chatRequestUserId + "";
// 把获取的消息存入缓存
that.set_chat_storage(chatRequestUserId, msg_obj);
that.update_unread_msg(chatRequestUserId, msg_obj);
})
}
})
})
console.log('webSocket is open');
})
that.globalData.socketTask.onClose(function(res){
that.globalData.isConnect = false;
})
clearInterval(wss_linker); //停止计时器
} else {
console.log('还没有链接')
}
}, 1000)
}
- closeSocket函数
/**
* 关闭socket
*/
closeSocket(){
var that=this;
that.globalData.socketTask.close();
clearInterval(that.globalData.keepConnectInterval);
}
在connectSocket函数中,将建立socket链接返回的socketTask储存在全局变量,用以后续的消息监听、消息发送和socket断开。同时,这里用了全局变量,是为了保持链接一直只有一个。减少程序
错误的情况
ps:这个项目要求在小程序里面做一个聊天的模块=-= 不过也借此熟悉了socket的前后端应用
微信小程序websocket的更多相关文章
- 微信小程序 WebSocket 使用非 443 端口连接
前言 微信小程序支持使用 WebSocket 连接到服务器,准确地说是带 SSL 的 WebSocket,而微信小程序中不允许使用带端口的 wss 连接,只能使用 443 端口.想使用其他端口就需要在 ...
- 微信小程序-WebSocket
wx.connectSocket(OBJECT) 创建一个 WebSocket 连接:一个微信小程序同时只能有一个 WebSocket 连接,如果当前已存在一个 WebSocket 连接,会自动关闭该 ...
- 微信小程序-WebSocket应用
为何有 HTTP 协议还需要 WebSocket ? Http协议 有个缺陷:通信只能由客户端发起.举例来说,我们想了解今天的天气,只能是客户端向服务器发出请求,服务器返回查询结果.HTTP 协议做不 ...
- 快速上手微信小程序webSocket
WebSocket是一种在单个TCP连接上进行全双工通信的协议.WebSocket通信协议于2011年被IETF定为标准RFC 6455,并由RFC7936补充规范.WebSocket API也被W3 ...
- 微信小程序WebSocket报错:Error during WebSocket handshake: Sent non-empty 'Sec-WebSocket-Protocol' header but no response was received
Error during WebSocket handshake: Sent non-empty 'Sec-WebSocket-Protocol' header but no response was ...
- 微信小程序(应用号)资源汇总整理
微信小应用资源汇总整理 开源项目 WeApp - 微信小程序版的微信 wechat-weapp-redux-todos - 微信小程序集成Redux实现的Todo list wechat-weapp- ...
- 微信小程序(应用号)开发资源汇总整理 - 一直更新中
开源项目 wechat-weapp-gank - 微信小程序版Gank客户端 wechat-dribbble - 微信小程序-Dribbble wechatApp-demo - 微信小程序 DEMO ...
- 黄聪:微信小程序(应用号)资源汇总整理(转)
微信小应用资源汇总整理 开源项目 WeApp - 微信小程序版的微信 wechat-weapp-redux-todos - 微信小程序集成Redux实现的Todo list wechat-weapp- ...
- 微信小程序踩坑集合
1:官方工具:https://mp.weixin.qq.com/debug/w ... tml?t=1476434678461 2:简易教程:https://mp.weixin.qq.com/debu ...
随机推荐
- imx6的kernel3.4.15启动流程
//最开始的定义为 DT_MACHINE_START(IMX6Q, "Freescale i.MX6 Quad/DualLite (Device Tree)") .smp = sm ...
- [转]使用EntityFramework6.1的DbCommandInterceptor拦截生成的SQL语句
本文转自:http://www.cnblogs.com/Ax0ne/p/3620958.html 开始 EF6.1也出来不少日子了,6.1相比6.0有个很大的特点就是新增了System.Data.En ...
- dev中文本框等获取焦点事件
<ClientSideEvents GotFocus="GotFocus" /> editContract.SetFocus()//设置文本框等的焦点 function ...
- BG.VM--CentOS
1. CentOS 更改IP 局域网配置: 在虚拟机的[网络]连接方式中选择:仅主机(Host-Only)网络. 路径:vim /etc/sysconfig/network-scripts/ifcfg ...
- C#:ORM--实体框架EF(entity framework)(1)
本文来自:http://www.cnblogs.com/xuf22/articles/5513283.html 一.什么是ORM ORM(Object-relational mapping),中文翻译 ...
- Centos系统下卸载、安装MySQL及用户的创建、授权和使用(详细。。。。)
由于经常使用linux系统,并且大数据环境搭建中经常会使用到mysql,不像windows系统下的安装,今天有点空写一篇,下面我给大家演示一遍. 主要有三部分内容: 1.MySQL的卸载 2.MySQ ...
- 深入理解MyBatis的原理(三):配置文件(上)
前言:前文提到一个入门的demo,从这里开始,会了解深入 MyBatis 的配置,本文讲解 MyBatis 的配置文件的用法. 目录 1.properties 元素 2.设置(settings) 3. ...
- AutoFac使用方法总结四:生命周期续
控制反转(IoC/Inverse Of Control): 调用者不再创建被调用者的实例,由autofac框架实现(容器创建)所以称为控制反转. 依赖注入(DI/Depende ...
- Java8简明学习之Optional
Java在8的版本,新增了Optional和lambda表达式,使得日常开发中对于NullPointException的判断变的优雅. 现在来个例子看看在Optional之前对空的判断. @Test ...
- 【PyQt5 学习记录】006:重写窗口事件及QMessageBox
#!/usr/bin/env python import sys from PyQt5.QtWidgets import (QApplication, QMainWindow, QMessageBox ...