示例:前端發送數據到后端,然后后端推送數據到前端。
<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認證與授權
- 環境搭建
- 密碼加密
- 認證與授權