博客简介
本篇博客介绍微信小程序中webSocket的使用方法,以及如何用局部网络建立webSocket连接,进行客户端与服务器之间的对话:
- webSocket简介
- 微信小程序端API调用
- 服务器端使用nodejs配置
- 演示websocket
webSocket简介
WebSocket 是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在 WebSocket API 中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。在 WebSocket API 中,浏览器和服务器只需要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送。
现在,很多网站为了实现推送技术,所用的技术都是 Ajax 轮询。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP请求,然后由服务器返回最新的数据给客户端的浏览器。这种传统的模式带来很明显的缺点,即浏览器需要不断的向服务器发出请求,然而HTTP请求可能包含较长的头部,其中真正有效的数据可能只是很小的一部分,显然这样会浪费很多的带宽等资源。HTML5 定义的 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
(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建立环境
- 回车之后就能看到目录下生成了文件,环境就生成完毕,接下来就要写服务端的代码了
(2)引入ws模块的构造函数并且实例化
在websocket下创建一个文件server.js,用来编写nodejs代码,首先我们要引入ws模块的构造函数并且实例化:
引入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代码
- 在微信开发者工具中编译,运行小程序
- 输入消息,观察反馈
(1)小程序和服务器建立连接
小程序和服务器建立连接后显示:
服务器端显示建立成功
(2)小程序向服务器发送给消息
在文本框中输入内容,发送消息,服务器接收到后:
小程序获取到服务器回发的消息:
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]