微信小程序 websocket 实现SpringMVC+Spring+Mybatis
发布时间 - 2026-01-11 02:38:33 点击率:次微信小程序实现websocket步骤:

后台:
1. 添加maven依赖 2. 创建握手 3. 创建处理器 4. spring配置(xml配置或javabean方式配置任选一种)
微信小程序:
1. 书写连接
java后台
1.添加maven依赖
<!-- websocket -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-websocket</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-messaging</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- 其中spring版本 -->
<!-- 注意spring版本一定要为4以上版本 -->
<spring.version>4.3.7.RELEASE</spring.version>
2.创建握手
package com.ahutshop.websocket;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.springframework.http.server.ServerHttpRequest;
import org.springframework.http.server.ServerHttpResponse;
import org.springframework.http.server.ServletServerHttpRequest;
import org.springframework.web.socket.WebSocketHandler;
import org.springframework.web.socket.server.HandshakeInterceptor;
/**
* 此类用来获取登录用户信息并交由websocket管理
*/
public class MyWebSocketInterceptor implements HandshakeInterceptor {
@Override
public boolean beforeHandshake(ServerHttpRequest request, ServerHttpResponse arg1, WebSocketHandler arg2,
Map<String, Object> arg3) throws Exception {
// 将ServerHttpRequest转换成request请求相关的类,用来获取request域中的用户信息
if (request instanceof ServletServerHttpRequest) {
ServletServerHttpRequest servletRequest = (ServletServerHttpRequest) request;
HttpServletRequest httpRequest = servletRequest.getServletRequest();
}
System.out.println("连接到我了");
return true;
}
@Override
public void afterHandshake(ServerHttpRequest arg0, ServerHttpResponse arg1, WebSocketHandler arg2, Exception arg3) {
// TODO Auto-generated method stub
}
}
3.创建处理器
package com.ahutshop.websocket;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import org.springframework.web.socket.CloseStatus;
import org.springframework.web.socket.TextMessage;
import org.springframework.web.socket.WebSocketHandler;
import org.springframework.web.socket.WebSocketMessage;
import org.springframework.web.socket.WebSocketSession;
public class WebSocketPushHandler implements WebSocketHandler {
private static final List<WebSocketSession> users = new ArrayList<>();
// 用户进入系统监听
@Override
public void afterConnectionEstablished(WebSocketSession session) throws Exception {
System.out.println("成功进入了系统。。。");
users.add(session);
sendMessagesToUsers(new TextMessage("今天晚上服务器维护,请注意"));
}
//
@Override
public void handleMessage(WebSocketSession session, WebSocketMessage<?> message) throws Exception {
// 将消息进行转化,因为是消息是json数据,可能里面包含了发送给某个人的信息,所以需要用json相关的工具类处理之后再封装成TextMessage,
// 我这儿并没有做处理,消息的封装格式一般有{from:xxxx,to:xxxxx,msg:xxxxx},来自哪里,发送给谁,什么消息等等
// TextMessage msg = (TextMessage)message.getPayload();
// 给所有用户群发消息
//sendMessagesToUsers(msg);
// 给指定用户群发消息
//sendMessageToUser(userId, msg);
}
// 后台错误信息处理方法
@Override
public void handleTransportError(WebSocketSession session, Throwable exception) throws Exception {
}
// 用户退出后的处理,不如退出之后,要将用户信息从websocket的session中remove掉,这样用户就处于离线状态了,也不会占用系统资源
@Override
public void afterConnectionClosed(WebSocketSession session, CloseStatus closeStatus) throws Exception {
if (session.isOpen()) {
session.close();
}
users.remove(session);
System.out.println("安全退出了系统");
}
@Override
public boolean supportsPartialMessages() {
return false;
}
/**
* 给所有的用户发送消息
*/
public void sendMessagesToUsers(TextMessage message) {
for (WebSocketSession user : users) {
try {
// isOpen()在线就发送
if (user.isOpen()) {
user.sendMessage(message);
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
/**
* 发送消息给指定的用户
*/
public void sendMessageToUser(String userId, TextMessage message) {
for (WebSocketSession user : users) {
if (user.getAttributes().get("").equals(userId)) {
try {
// isOpen()在线就发送
if (user.isOpen()) {
user.sendMessage(message);
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}
4.spring配置
javabean方式配置(推荐)
package com.ahutshop.websocket;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
import org.springframework.web.socket.WebSocketHandler;
import org.springframework.web.socket.config.annotation.EnableWebSocket;
import org.springframework.web.socket.config.annotation.WebSocketConfigurer;
import org.springframework.web.socket.config.annotation.WebSocketHandlerRegistry;
@Configuration
@EnableWebSocket
public class WebSocketConfig extends WebMvcConfigurerAdapter implements WebSocketConfigurer {
@Override
public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) {
registry.addHandler(WebSocketPushHandler(), "/webSocketServer.action").addInterceptors(new MyWebSocketInterceptor()).setAllowedOrigins("*");
registry.addHandler(WebSocketPushHandler(), "/sockjs/webSocketServer.action")
.addInterceptors(new MyWebSocketInterceptor()).withSockJS();
}
@Bean
public WebSocketHandler WebSocketPushHandler() {
return new WebSocketPushHandler();
}
}
spring.xml中配置扫描包
<!-- 扫描包 -->
<context:component-scan base-package="com.ahutshop.websocket" />
注意:
1. /webSocketServer.action之所以要加上.action的后缀,是因为web.xmlk中配置了拦截的后缀名为.action
<!-- springmvc模块 -->
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
<!-- 支持异步 -->
<async-supported>true</async-supported>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>*.action</url-pattern>
</servlet-mapping>
2 .setAllowedOrigins(“*”)中的*代表合法的请求域名,该方法接受一个可变数组作为参数,一定要配置,不然会请求时会出现403
xml方式配置(省略)
微信小程序
1.websocket.wxml
<!--pages/websocket/websocket.wxml--> <view class="page"> <view class="page__hd"> </view> <view class="page__bd"> <button bindtap="connectWebsocket" type="primary">连接websocket</button> </view> </view>
2.websocket.js
// pages/websocket/websocket.js
Page({
/**
* 页面的初始数据
*/
data: {
},
connectWebsocket: function () {
wx.connectSocket({
url: 'ws://localhost:8080/AhutShop/webSocketServer.action',
data: {
},
header: {
'content-type': 'application/json'
},
method: "GET"
})
wx.onSocketOpen(function (res) {
console.log('WebSocket连接已打开!')
})
wx.onSocketError(function (res) {
console.log('WebSocket连接打开失败,请检查!')
})
wx.onSocketMessage(function (res) {
console.log('收到服务器内容:' + res.data)
})
}
})
运行效果
以上就是微信小程序 后台的建立,如有疑问请留言或者到本站社区交流讨论,本站关于微信小程序的文章还有很多,希望大家多多搜索查阅,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# 微信小程序
# websocket
# 小程序后台开发
# 详解SpringMVC在IDEA中的第一个程序
# SpringMVC程序简单实例
# 分析讲解SpringMVC注解配置如何实现
# SpringMVC底层执行流程及原理解析
# 世界著名程序SpringMVC完整过程
# 发送消息
# 离线
# 是因为
# 出了
# 如有
# 希望能
# 此类
# 我了
# 请注意
# 要将
# 谢谢大家
# 转换成
# 错误信息
# 还有很多
# 连接到
# 需要用
# 大家多多
# 某个人
# 给谁
# 我这儿
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
如何快速生成凡客建站的专业级图册?
Claude怎样写约束型提示词_Claude约束提示词写法【教程】
作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】
Laravel如何使用Laravel Vite编译前端_Laravel10以上版本前端静态资源管理【教程】
Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践
如何快速查询域名建站关键信息?
如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环
大学网站设计制作软件有哪些,如何将网站制作成自己app?
如何用腾讯建站主机快速创建免费网站?
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】
原生JS实现图片轮播切换效果
在centOS 7安装mysql 5.7的详细教程
PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)
如何快速搭建二级域名独立网站?
Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明
Laravel Fortify是什么,和Jetstream有什么关系
JavaScript如何操作视频_媒体API怎么控制播放
googleplay官方入口在哪里_Google Play官方商店快速入口指南
Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能
如何在云主机快速搭建网站站点?
微信小程序 闭包写法详细介绍
如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧
Laravel如何实现事件和监听器?(Event & Listener实战)
Laravel如何发送系统通知?(Notification渠道示例)
谷歌Google入口永久地址_Google搜索引擎官网首页永久入口
Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全
JavaScript如何实现继承_有哪些常用方法
如何使用 jQuery 正确渲染 Instagram 风格的标签列表
如何快速搭建安全的FTP站点?
Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】
进行网站优化必须要坚持的四大原则
Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程
iOS正则表达式验证手机号、邮箱、身份证号等
如何在阿里云购买域名并搭建网站?
Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置
无锡营销型网站制作公司,无锡网选车牌流程?
laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法
Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用
Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
开心动漫网站制作软件下载,十分开心动画为何停播?
如何快速辨别茅台真假?关键步骤解析
Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)
如何利用DOS批处理实现定时关机操作详解
jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】
如何在 Pandas 中基于一列条件计算另一列的分组均值

