微信小程序webSocket的使用方法


Posted in Javascript onFebruary 20, 2020

博客简介

本篇博客介绍微信小程序中webSocket的使用方法,以及如何用局部网络建立webSocket连接,进行客户端与服务器之间的对话:

  • webSocket简介
  • 微信小程序端API调用
  • 服务器端使用nodejs配置
  • 演示websocket

webSocket简介

WebSocket 是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在 WebSocket API 中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。在 WebSocket API 中,浏览器和服务器只需要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送。

现在,很多网站为了实现推送技术,所用的技术都是 Ajax 轮询。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP请求,然后由服务器返回最新的数据给客户端的浏览器。这种传统的模式带来很明显的缺点,即浏览器需要不断的向服务器发出请求,然而HTTP请求可能包含较长的头部,其中真正有效的数据可能只是很小的一部分,显然这样会浪费很多的带宽等资源。HTML5 定义的 WebSocket 协议,能更好的节省服务器资源和带宽,并且能够更实时地进行通讯。

微信小程序webSocket的使用方法

微信小程序端API调用

微信小程序端需要做的配置有:

  • 获取局部网络的地址
  • SocketTask wx.connectSocket创建一个 WebSocket 连接。
  • wx.onSocketOpen(function callback)监听 WebSocket 连接打开事件
  • wx.sendSocketMessage(Object object) 连接发送数据。
  • wx.onSocketMessage(function callback)监听 WebSocket 接受到服务器的消息事件

(1)获取局部网络的地址IP

获取局部网络的IP十分简单,打开设置,进入网络,点击WiFi属性,在IPv4右侧就能看见IP地址然后,在IP的前面加上ws://尾部加上3001得到可用的IP:
例如:

ws://199.213.7.102:3001

微信小程序webSocket的使用方法

(2)建立客户端和服务器的链接,并且发送消息,监听服务器回发消息

在wxml部分设置一个按钮,用来获取信息亲切发送消息:

WXML:

<input type="tex" bindchange="sendMessage" class="text" placeholder="请输入消息"></input>

JS部分建立客户端和服务器的链接,并且发送消息,监听服务器回发消息:

//本地服务器地址
var wsApi = "ws://199.213.7.102:3001";
var socketOpen==false;
 sendMessage:function(e)
 {
  var msg=e.detail.value;
   if (socketOpen) {
    console.log(msg);
    //向服务器发送消息
    wx.sendSocketMessage({
     data: msg
    })
  }
 },
 onLoad: function (options) {
  //建立连接
   wx.connectSocket({
    url: wsApi,
    header: {
     'content-type': 'application/json'
    },
    //method:"GET",
    protocols: ['protocol1'],
    success: function () {
     console.log("客户端连接成功!");
     wx.onSocketOpen(function(){
      console.log('webSocket已打开!');
      socketOpen=true;
      wx.onSocketMessage(function(msg){
        console.log(msg);
      })
     })
    }
   })
 },

服务器端使用nodejs配置

服务器这里用的是nodejs来配置,当然你也可以用其他后端语言来处理。假设你已经安装好了nodejs,那么我们开始吧:

  • 创建nodejs环境
  • 引入ws模块的构造函数并且实例化
  • 监听前端发送的消息
  • 回发消息

(1)创建nodejs环境

  • 首先新建一个文件夹websocket
  • window+R,输入cmd
  • 输入cd 空格后将websocket直接拖拽到黑框内(或者cd 路径)进入websocket文件夹
  • 接着输入npm install ws建立环境
  • 回车之后就能看到目录下生成了文件,环境就生成完毕,接下来就要写服务端的代码了

微信小程序webSocket的使用方法

微信小程序webSocket的使用方法

微信小程序webSocket的使用方法

(2)引入ws模块的构造函数并且实例化

在websocket下创建一个文件server.js,用来编写nodejs代码,首先我们要引入ws模块的构造函数并且实例化:

微信小程序webSocket的使用方法

引入ws模块的构造函数并且实例化:

//引入ws模块的构造函数
var webSocketServer=require("ws").Server;
//实例化
var wss=new webSocketServer({
	port:3001
});

(3)监听前端发送的消息

继续编写server.js,监听前端发送的消息:

  • wss.on(“connection”,function(ws)
  • ws.on(“message”,function(msg)
//引入ws模块的构造函数
var webSocketServer=require("ws").Server;
//实例化
var wss=new webSocketServer({
	port:3001
});
//监听客户端连接
wss.on("connection",function(ws){
	console.log("服务器连接建立成功");
	//监听客户端消息
	ws.on("message",function(msg){
		console.log(msg);
		ws.send("来自客户端的消息:"+msg);
	})
});

(4)回发消息

服务器接收消息之后,还要具备回发消息的能力,给客户端反馈消息,至于返回什么消息,不是我们这里要讨论的,我们直接简单的将客户发送的消息回发回去即可:

ws.send(“来自客户端的消息:”+msg)

//引入ws模块的构造函数
var webSocketServer=require("ws").Server;
//实例化
var wss=new webSocketServer({
	port:3001
});
//监听客户端连接
wss.on("connection",function(ws){
	console.log("服务器连接建立成功");
	//监听客户端消息
	ws.on("message",function(msg){
		console.log(msg);
		ws.send("来自客户端的消息:"+msg);
	})
});

演示websocket

最后我们简单地演示一下:

  • 在cmd中继续输入:node server.js,运行server.js代码
  • 在微信开发者工具中编译,运行小程序
  • 输入消息,观察反馈

微信小程序webSocket的使用方法

(1)小程序和服务器建立连接

小程序和服务器建立连接后显示:

微信小程序webSocket的使用方法

服务器端显示建立成功

微信小程序webSocket的使用方法

(2)小程序向服务器发送给消息

在文本框中输入内容,发送消息,服务器接收到后:

微信小程序webSocket的使用方法

微信小程序webSocket的使用方法

小程序获取到服务器回发的消息:

微信小程序webSocket的使用方法

到此这篇关于微信小程序webSocket的使用方法的文章就介绍到这了,更多相关小程序webSocket内容请搜素三水点靠木以前的文章或下面相关文章,希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
深入理解JavaScript定时机制
Oct 29 Javascript
Jquery动态进行图片缩略的原理及实现
Aug 13 Javascript
JS操作Cookies的小例子
Oct 15 Javascript
一个CSS+jQuery实现的放大缩小动画效果
Feb 19 Javascript
BootStrap selectpicker
Jun 20 Javascript
js鼠标经过tab选项卡时实现切换延迟
Mar 24 Javascript
Vue2.0 vue-source jsonp 跨域请求
Aug 04 Javascript
vue数据控制视图源码解析
Mar 28 Javascript
vue使用better-scroll实现下拉刷新、上拉加载
Nov 23 Javascript
vue鼠标悬停事件实例详解
Apr 01 Javascript
JavaScript Array.flat()函数用法解析
Sep 02 Javascript
vue中defineProperty和Proxy的区别详解
Nov 30 Vue.js
Javascript Worker子线程代码实例
Feb 20 #Javascript
vue中音频wavesurfer.js的使用方法
Feb 20 #Vue.js
Javascript原生ajax请求代码实例
Feb 20 #Javascript
webpack中的模式(mode)使用详解
Feb 20 #Javascript
jquery向后台提交数组的代码分析
Feb 20 #jQuery
koa-passport实现本地验证的方法示例
Feb 20 #Javascript
javaScript 实现重复输出给定的字符串的常用方法小结
Feb 20 #Javascript
You might like
PHP 在5.1.* 和5.2.*之间 PDO数据库操作中的不同之处小结
2012/03/07 PHP
PHP删除目录及目录下所有文件的方法详解
2013/06/06 PHP
一个非常完美的读写ini格式的PHP配置类分享
2015/02/12 PHP
ThinkPHP 5 AJAX跨域请求头设置实现过程解析
2020/10/28 PHP
JavaScript内核之基本概念
2011/10/21 Javascript
解析Jquery中如何把一段html代码动态写入到DIV中(实例说明)
2013/07/09 Javascript
判断是否安装flash player及当前版本的JS代码
2013/08/08 Javascript
Javascript中的方法链(Method Chaining)介绍
2015/03/15 Javascript
3种js实现string的substring方法
2015/11/09 Javascript
JS判断是否长按某一键的方法
2016/03/02 Javascript
JavaScript导航脚本判断当前导航
2016/07/12 Javascript
简单模拟node.js中require的加载机制
2016/10/27 Javascript
js实现百度搜索提示框
2017/02/05 Javascript
javascript checkbox/radio onchange不能兼容ie8处理办法
2017/06/13 Javascript
JS实现页面内跳转的简单代码
2017/09/03 Javascript
详解webpack 打包文件体积过大解决方案(code splitting)
2018/04/10 Javascript
VUE 3D轮播图封装实现方法
2018/07/03 Javascript
layui实现点击按钮给table添加一行
2018/08/10 Javascript
Webpack4 使用Babel处理ES6语法的方法示例
2019/03/07 Javascript
微信小程序单选radio及多选checkbox按钮用法示例
2019/04/30 Javascript
js变量值传到php过程详解 将php解析成数据
2019/06/26 Javascript
Python实现针对中文排序的方法
2017/05/09 Python
Python编程pygal绘图实例之XY线
2017/12/09 Python
详解python中的装饰器
2018/07/10 Python
python读取word文档,插入mysql数据库的示例代码
2018/11/07 Python
python3对拉勾数据进行可视化分析的方法详解
2019/04/03 Python
Python Matplotlib绘图基础知识代码解析
2020/08/31 Python
2014全国两会大学生学习心得体会
2014/03/10 职场文书
团队精神的演讲稿
2014/05/14 职场文书
党员承诺书范文
2014/05/19 职场文书
计算机售后服务承诺书
2014/05/30 职场文书
挂职学习心得体会
2014/09/09 职场文书
迎新生欢迎词2015
2015/07/16 职场文书
CSS 使用 resize 实现图片拖拽切换预览功能(强大功能)
2021/08/23 HTML / CSS
React Fragment介绍与使用详解
2021/11/11 Javascript
Java tomcat手动配置servlet详解
2021/11/27 Java/Android