uniapp 使用 websocket

原理和vue使用是一样的,这里就不多说了,可以去看我之前发的 websocket 的使用

传送门:WebScoket 使用教程

直接看代码:

(1)先创建一个ws的连接。

在各个小程序平台运行时,网络相关的 API 在使用前需要配置域名白名单。

javascript 复制代码
data() {
    return {
        socketTask: '',
        ...
    }
},
methods: {
    connectSocketInit(mid){
        // 创建一个this.socketTask对象【发送、接收、关闭socket都由这个对象操作】
        this.socketTask = uni.connectSocket({
            url: `wss://ws的地址`,
		    success(data) {
		        console.log("websocket连接成功lolo ");
		    },
        });
    }
(2)发送初始订阅消息
  • 当WebSocket连接打开时 (onOpen 事件),将发送一条JSON格式的消息给服务器。
  • 消息内容包括客户端信息、意图、客户端ID、组织ID和频道ID列表。
javascript 复制代码
connectSocketInit(mid) {
    ...
    var prmsg = `更具自己项目需要绑定发送的数据`;
    this.socketTask.onOpen((res) => { //发送消息
        this.socketTask.send({
            data: prmsg,
		});
    })
}
(3)接收并处理消息
  • 使用 onMessage 监听器来接收从服务器发来的消息。
javascript 复制代码
connectSocketInit(mid) {
    this.socketTask.onOpen((res) => { //发送消息
        ...
        this.socketTask.onMessage((res) => {
		    let evtObj = JSON.parse(res.data);
			console.log('ws推送', evtObj)
        })
    }}
        
}
(4)关闭连接处理
  • 使用 onClose 监听器来处理连接关闭的情况,当连接关闭时会在控制台输出 "ws已经被关闭"。
javascript 复制代码
connectSocketInit(mid) {
    ...
    // socket关闭执行
	this.socketTask.onClose(() => {
		console.log("ws已经被关闭")
	})
},
closeSocket() { //关闭链接
    this.socketTask.close({
		success(res) {
			console.log("关闭成功", res)
		},
		fail(err) {
			console.log("关闭失败", err)
		}
	})
},

注意:

  • 确保在适当的地方调用 closeSocket() 来释放资源。
  • 处理好错误和异常情况,保证用户体验。
  • 安全性考虑:确保所有传输的数据都是加密的,并且只向授权的用户展示敏感信息

这样 uniapp 中 webSocket 就能使用了,其他可参照官网进行开发

相关推荐
用户904706683577 小时前
uniapp Vue3版本,用pinia存储持久化插件pinia-plugin-persistedstate对微信小程序的配置
前端·uni-app
细节控菜鸡9 小时前
【2025最新】uniapp 中基于 request 封装实现多文件上传完整指南
uni-app
fakaifa9 小时前
【全开源】企业微信SCRM社群营销高级版系统+uniapp前端
uni-app·开源·企业微信·scrm·源码下载·企业微信scrm
棋子一名11 小时前
跑马灯组件 Vue2/Vue3/uni-app/微信小程序
微信小程序·小程序·uni-app·vue·js
游戏开发爱好者813 小时前
BShare HTTPS 集成与排查实战,从 SDK 接入到 iOS 真机调试(bshare https、签名、回调、抓包)
android·ios·小程序·https·uni-app·iphone·webview
2501_9160088913 小时前
iOS 26 系统流畅度实战指南|流畅体验检测|滑动顺畅对比
android·macos·ios·小程序·uni-app·cocoa·iphone
2501_9151063215 小时前
苹果软件加固与 iOS App 混淆完整指南,IPA 文件加密、无源码混淆与代码保护实战
android·ios·小程序·https·uni-app·iphone·webview
2501_9159214315 小时前
iOS 26 崩溃日志解析,新版系统下崩溃获取与诊断策略
android·ios·小程序·uni-app·cocoa·iphone·策略模式
2501_9160137418 小时前
iOS 推送开发完整指南,APNs 配置、证书申请、远程推送实现与上架调试经验分享
android·ios·小程序·https·uni-app·iphone·webview
2501_915909061 天前
HTML5 与 HTTPS,页面能力、必要性、常见问题与实战排查
前端·ios·小程序·https·uni-app·iphone·html5