示例:前端发送数据到后端,然后后端推送数据到前端。
<br/>
**1. 一个SpringBoot项目**
```xml
<!-- websocket依赖 -->
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-websocket</artifactId>
</dependency>
</dependencies>
```
**2. 注册websocket配置类**
```java
/**
* 1. 实现接口 WebSocketMessageBrokerConfigurer
* 2. @EnableWebSocketMessageBroker将当前类标注为websocket服务器
*/
@Configuration
@EnableWebSocketMessageBroker
public class WebSocketConfig implements WebSocketMessageBrokerConfigurer {
/**
* 注册websocket服务器的访问地址
*/
@Override
public void registerStompEndpoints(StompEndpointRegistry registry) {
registry.addEndpoint("/endpoint-websocket") //websocket服务器访问地址
.setAllowedOrigins("*") //允许跨越访问
.withSockJS(); //支持客户端使用socketjs连接
}
/**
* 配置消息代理
*/
@Override
public void configureMessageBroker(MessageBrokerRegistry registry) {
//服务端向客户端通信时需要添加的地址前缀
registry.enableSimpleBroker("/topic");
//客户端向服务端通信时需要添加的地址前缀
registry.setApplicationDestinationPrefixes("/app");
}
}
```
**3. controller层代码**
```java
@RestController
public class TestController {
@MessageMapping("/v1/chat")
public String chatInfo(String message) {
System.out.println("服务端收到消息:" + message);
return "服务端:我已经收到消息!";
}
}
```
**4. 前端代码**
```html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Websocket03</title>
<script src="https://cdn.bootcss.com/sockjs-client/1.1.4/sockjs.min.js"></script>
<script src="https://cdn.bootcss.com/stomp.js/2.3.3/stomp.min.js"></script>
<script src="https://cdn.bootcss.com/stomp.js/2.3.3/stomp.js"></script>
</head>
<body>
<div id="app">
<button onclick="connect()">建立连接</button>
<br/>
<button onclick="disconnect()">断开连接</button>
<br/>
<button onclick="send()">发送数据</button>
<br/>
</div>
</body>
<script type="text/javascript">
var client = null
/**
* 连接服务端
*/
function connect() {
const socket = new SockJS('http://localhost:8083/endpoint-websocket')
client = Stomp.over(socket)
client.connect({}, (frame) => {
console.info("服务端已连接:", frame)
})
}
/**
* 断开与服务端的连接
*/
function disconnect() {
if (client != null) {
client.disconnect()
}
console.info('已断开连接')
}
/**
* 向服务端发送消息并获取响应
*/
function send() {
//客户端向服务端发送数据,注意看地址是以/app为前缀
client.send('/app/v1/chat', {}, 'Hello World!')
//获取服务端返回的数据,注意看是以/topic为前缀
client.subscribe('/topic/v1/chat', (res) => {
console.info(res.body)
})
}
</script>
</html>
```
**5. 效果演示**
当前端发送消息到后端后,输出如下。
```
----后端输出----
服务端收到消息:Hello World!
----前端输出----
服务端:我已经收到消息!
```
- 跨域问题
- 跨域是什么
- 跨域解决方案
- 从后端解决
- nginx反向代理
- WebSocket
- websocket是什么
- websocket协议
- 使用场景
- 实现方式
- 注解与html5原生方式
- websocketAPI
- 实现步骤
- 文件上传
- 文件下载
- 广播通信
- 定时推送
- 编程与socketjs方式
- socketjs与stompjs框架
- 实现步骤
- 重载目的地
- SimpMessagingTemplate
- 定时向前端推送数据
- 5种监听事件
- 点对点通信
- 拦截器
- HandshakeInterceptor
- ChannelInterceptor
- poi之excel表格
- 表格版本
- POI常用类
- POI依赖
- 写表格
- 编写表格过程
- 单元格边框样式
- 单元格背景色
- 冻结行或列
- 单元格合并
- 单元格内换行
- 文档内跳转
- 读表格
- Web中的Excel操作
- 导出表格
- 读取表格
- poi之word文档
- word版本
- 写word
- 基本使用
- 标题样式
- 添加图片
- EasyExcel表格
- EasyExcel是什么
- 与其他Excel工具对比
- EasyExcel依赖
- 读Excel
- 简单读取
- 指定列位置
- 读取多个sheet
- 格式转换
- 多行表头
- 同步读
- 写Excel
- 简单写入
- 单元格样式
- 拦截器
- 列宽
- 冻结行或列
- 合并单元格
- 填充Excel
- SpringSecurity
- SpringSecurity是什么
- 同类型产品对比
- 环境搭建
- 相关概念
- 密码加密
- Web权限控制
- UserDetailsService接口
- 登录认证
- 自定义登录页
- 未授权跳转登录页
- 权限控制
- 自定义403页面
- 权限注解
- 记住我功能
- 注销功能
- CSRF
- CSRF是什么
- CSRF保护演示
- 前后端分离权限控制
- 环境搭建
- 认证实现
- 会话管理
- 动态权限管理
- 微服务权限控制
- 权限控制方案
- SpringBoot整合RabbitMQ
- 整合步骤
- Fanout交换机演示
- Direct交换机演示
- Topic交换机演示
- @RabbitListener方法
- JWT认证与授权
- 环境搭建
- 密码加密
- 认证与授权