案例代碼:https://gitee.com/flymini/example-codes/tree/master/WebSocket_/com-learn-websocket04
****
實現客戶端向后端發送數據,然后后端將數據推送到前端。
<br/>
步驟如下:
**1. 創建一個 SpringBoot 項目**
```xml
<!-- 引入 websocket 依賴 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-websocket</artifactId>
</dependency>
```
**2. 編寫掃描注解`@ServerEndpoint`的配置類**
```java
@Configuration
public class WebSocketConfig {
/**
* 掃描標注了注解 @ServerEndpoint 的類,讓被標注的類成為 WebSocket 的服務類
*/
@Bean
public ServerEndpointExporter serverEndpointExporter() {
return new ServerEndpointExporter();
}
}
```
**3. 編寫 WebSocket 服務類**
```java
/**
* value:當前 WebSocket 服務的訪問地址
*/
@Component
@ServerEndpoint(value = "/v1/endpoint")
public class EndPointController {
/**
* 連接建立時被調用。
*/
@OnOpen
public void onOpen(Session session, EndpointConfig config) {
System.out.println("連接已經建立.");
}
/**
* 收到消息時被調用。
* @param message 前端傳遞過來的消息。
* @param session
*/
@OnMessage
public void onMessage(String message, Session session) throws IOException {
System.out.println("收到了消息:" + message);
//將消息推送到前端
session.getBasicRemote().sendText("謝謝,我收到了你的消息:" + message);
}
/**
* 連接關閉時被調用.
*
* @param session
* @param reason 關閉的理由
*/
@OnClose
public void onClose(Session session, CloseReason reason) {
System.out.println("連接已關閉,關閉理由:" + reason);
}
/**
* 當連接發生異常時被調用
*
* @param session
* @param e
*/
@OnError
public void onError(Session session, Throwable e) {
System.out.println("連接發生異常:" + e.getMessage());
e.printStackTrace();
}
}
```
**4. 前端程序**
```js
var sock = null
/**
* 建立連接
*/
function connect() {
sock = new WebSocket('ws://localhost:8090/v1/endpoint')
//當接收到服務端推送過來的消息時被觸發
sock.onmessage = (e) => {
console.log(e.data)
}
}
/**
* 發送數據到服務端
*/
function send() {
sock.send('Hello World!')
}
/**
* 關閉當前用戶與WebSocket的連接
*/
function close() {
sock.close(3000, "我想關閉連接!")
}
```
- 跨域問題
- 跨域是什么
- 跨域解決方案
- 從后端解決
- 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認證與授權
- 環境搭建
- 密碼加密
- 認證與授權