服务端

在windows下执行 node  server.js

也可参照我的前一篇部署https

var httpServ = require('http')
var WebSocketServer = require('ws').Server;
var app = httpServ.createServer().listen(8080);
var ws = new WebSocketServer({
server: app
}); ws.on('connection', function(wsConnect) {
wsConnect.on('message', function(message) {
console.log(message);
wsConnect.send('reply');
});
wsConnect.on('close', function (code, reason) {
console.log('关闭连接', code, reason)
});
wsConnect.on('error', function (code, reason) {
console.log('异常关闭', code, reason)
});
})

客户端

这里介绍两种客户端,一种是微信小程序,一种是html网页。

微信小程序

代码示例:

xxx.wxml

<button bindtap='startClick'>连接</button>
<button bindtap='sendClick'>发送</button>
<button bindtap='closeClick'>断开</button>

xxx.js

Page({

  /**
* 页面的初始数据
*/
data: {
isConnect: null,
}, startClick(even) {
wx.connectSocket({
url: 'ws://localhost:8080/',
method: 'GET',
success: (res) => {
isConnect: true
console.log("连接成功", res)
},
fail: (res) => {
isConnect: false
console.log("连接失败", res)
}
}); wx.onSocketOpen((res) => {
console.log('WebSocket连接已打开!')
}); wx.onSocketError((res) => {
console.log('WebSocket连接打开失败,请检查!')
})
}, sendClick: function (even) {
wx.sendSocketMessage({
data: "From微信小程序 web socket"
})
}, closeClick(even) {
wx.closeSocket({
success: (res) => {
console.log("关闭成功...")
},
fail: (res) => {
console.log("关闭失败...")
}
});
wx.onSocketClose((res)=> {
console.log("WebSocket连接已关闭")
})
}, /**
* 生命周期函数--监听页面加载
*/
onLoad(options) {
wx.onSocketMessage((res) => {
console.log(res.data)
console.log(res)
})
}
})

效果截图:

网页

<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
<title>WebSocket</title>
<link href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap-theme.min.css" rel="stylesheet">
<link href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
<style>
body{
width: 96%;
margin-left: 2%;
margin-top: 20px;
}
</style>
</head>
<body>
<div class="btn-group box" role="group" aria-label="...">
<button type="button" class="btn btn-default">Oppo</button>
<button type="button" class="btn btn-default">Vivo</button>
<button type="button" class="btn btn-default">Apple</button>
</div>
<div class="page-header">
<h4 class="info">服务器返回信息列表:</br></br></h4>
</div>
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.js"></script>
<script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<script>
if (window.WebSocket) {
var ws = new WebSocket('ws://127.0.0.1:8080'); ws.onopen = function () {
console.log('连接服务器成功!');
ws.send('startting...');
}
ws.onclose = function () {
console.log('服务器关闭');
}
ws.onerror = function () {
console.log("连接出错");
} ws.onmessage = function (e) {
document.querySelector(".box").onclick = function (e) {
ws.send('当前点击框的内容为:<font style="color:red;" >' + e.target.innerHTML+'</font>');
}
$('.info').append(e.data + '</br></br>');
}
}
</script>
</body>
</html>

参考链接:

1. https://blog.csdn.net/potato512/article/details/79991342

2. https://blog.csdn.net/medivhq/article/details/75021382

微信小程序开发——websocket测试的更多相关文章

  1. 微信小程序开发学习资料

    作者:初雪链接:https://www.zhihu.com/question/50907897/answer/128494332来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...

  2. 微信小程序开发工具测评

    1月9日微信小程序正式上线.很多企业都希望能在这个.但是在技术开发的问题上,却不知道该如何下手.经过一些程序员不辞辛苦连夜测试,终于从十余款工具呕心沥血筛选出四款比较靠谱实用的微信小程序开发工具.接下 ...

  3. 微信小程序开发:http请求

    在微信小程序进行网络通信,只能和指定的域名进行通信,微信小程序包括四种类型的网络请求. 普通HTTPS请求(wx.request) 上传文件(wx.uploadFile) 下载文件(wx.downlo ...

  4. 微信小程序开发1

    关于微信小程序的开发.对于我们这些没学过oc或者android的人来说,无疑是一个令人鸡冻的好消息.这段时间研究了微信小程序开发.关于小程序的注册,认证和基础环境的搭建,官方文档已经非常详细了.这里就 ...

  5. 微信小程序开发 -- 01

    微信小程序开发基础 -- 开发前的准备 缘由 1月9日张小龙微信小程序正式上线,因为微信,所以小程序从诞生开始就头戴巨大的光环,很多的团队,公司以及开发的个体都眼巴巴的盯着这个小程序.而那个时候我却在 ...

  6. 微信小程序开发之模板

    一.简介 WXML提供模板(template),可以在模板中定义代码片段,然后在不同的地方调用. 定义模板 使用name属性,作为模板的名字.然后在<template/>内定义代码片段,如 ...

  7. 微信小程序开发06-一个业务页面的完成

    前言 接上文:微信小程序开发05-日历组件的实现 github地址:https://github.com/yexiaochai/wxdemo 这里来说一说我们的理念,我们也学习小程序开发有一周多了,从 ...

  8. 微信小程序开发 (资料汇总,谁还没被坑过?希望助你绕过一些坑)

    最近帮人家做一个微信小程序,刚好想熟悉一下.由于牵扯到多用户使用系统,以及数据共享,所以自然架构选择了,客户端和服务器的方式. 后台服务器是windows server,后台程序是.Net  WebA ...

  9. 微信小程序开发教程 #043 - 在小程序开发中使用 npm

    本文介绍了如何在微信小程序开发中使用 npm 中包的功能,大大提高微信小程序的开发效率,同时也是微信小程序系列教程的视频版更新. 微信小程序在发布之初没有对 npm 的支持功能,这也是目前很多前端开发 ...

随机推荐

  1. 【坑】Maven [ERROR] 不再支持源选项 5。请使用 6 或更高版本

    在pom.xml文件中添加如下代码: 注意:jdk使用自己下载的版本,我的是13 <properties> <project.build.sourceEncoding>UTF- ...

  2. C++常用的string字符串截断函数

    C++中经常会用到标准库函数库(STL)的string字符串类,跟其他语言的字符串类相比有所缺陷.这里就分享下我经常用到的两个字符串截断函数: #include <iostream> #i ...

  3. Burp Suite渗透操作指南 【暴力破解】

    1.1 Intruder高效暴力破解 其实更喜欢称Intruder爆破为Fuzzing.Intruder支持多种爆破模式.分别是:单一字典爆破.多字段相同字典爆破.多字典意义对应爆破.聚合式爆破.最常 ...

  4. 配置Postman通过OAuth 2 implicit grant获取Dynamics 365 CE Online实例的Access Token

    微软动态CRM专家罗勇 ,回复335或者20190516可方便获取本文,同时可以在第一间得到我发布的最新博文信息,follow me. 对于测试Web API, Get 类型,不需要设定特别reque ...

  5. KubeSphere and Friends|12 月 14 日相约北京,不见不散

    如今在容器圈提到 Kubernetes,可谓是无人不知无人不晓.KubeSphere 作为一款面向云原生设计的开源项目,目的是在 Kubernetes 之上构建分布式多租户容器管理平台,提供简单易用的 ...

  6. 32.Java基础_异常

    JVM虚拟机默认异常处理机制 Java异常处理: 1.try...catch... 2.throw 1.try...catch... public class test{ public static ...

  7. linux常用命令修改权限查看文档

    一.>和>>指令 >用于将执行结果写入后面的文件中: 把前方语句的结果存进文件,若文件不存在会自动创建 >:输出重定向 会覆盖原来文件内容 >>:追加重定向 ...

  8. swoole怎么保持不掉线

    正常情况下客户端中断TCP连接时,会发送一个FIN包,进行4次断开握手来通知服务器.但一些异常情况下,如客户端突然断电断网或者网络异常,服务器可能无法得知客户端已断开连接. 尤其是移动网络,TCP连接 ...

  9. python-16-初识函数

    前言 以前写的python代码都是像记流水账一样,那么函数时什么额?它可以在任何需要它的地方进行调用,函数分为: 内置函数,print(),len() 自定义函数 一.自定义函数 1.我们都知道内置函 ...

  10. ycsb 测试Hbase性能

    下载 github:https://github.com/brianfrankcooper/YCSB/releases/tag/0.10.0 wget https://github.com/brian ...