1)在項目中經常涉及到消息推送的狀況,消息推送要求的實時性,使用傳統的方式已經不能知足需求了;
2)使用netty-socketio作消息推送,實現步驟,加入jar包----->寫啓動,添加,通知,關閉工具類 -----> 設置依靠監聽器啓動 ----->頁面引入js----->編寫請求獲取消息;javascript
1)pom依賴與js文件:socket.io.js (見文章末尾附件包中)html
<dependencies> <dependency> <groupId>com.corundumstudio.socketio</groupId> <artifactId>netty-socketio</artifactId> <version>1.7.7</version> </dependency> </dependencies>
2)實現工具類java
/** * @author liudongyang * @ClassName: Socketio * @Description: netty-socketio工具類 建立、添加和啓動客戶端 消息推送 關閉服務 * @date 2018年11月27日 下午4:57:59 */ public class Socketio { private static SocketIOServer socketIOServer; /** * @Title: startSocketio * @Description: 建立服務添加客戶端 */ public void startSocketio() { // 配置 Configuration conf = new Configuration(); // 指定要主機ip地址,這個和頁面請求ip地址一致 conf.setHostname( "localhost" ); // 指定端口號 conf.setPort( 9092 ); // 設置最大的WebSocket幀內容長度限制 conf.setMaxFramePayloadLength( 1024 * 1024 ); // 設置最大HTTP內容長度限制 conf.setMaxHttpContentLength( 1024 * 1024 ); socketIOServer = new SocketIOServer( conf ); ConnectListener connect = new ConnectListener() { @Override public void onConnect( SocketIOClient client ) {} }; // 添加客戶端 socketIOServer.addConnectListener( connect ); socketIOServer.start(); } /** * @Title: pushArr * @Description: 全體消息推送 * @param type * 前臺根據類型接收消息,因此接收的消息類型不一樣,收到的通知就不一樣 推送的事件類型 * @param content * 推送的內容 */ public void pushArr( String type, Object content ) { // 獲取所有客戶端 Collection<SocketIOClient> allClients = socketIOServer.getAllClients(); for( SocketIOClient socket : allClients ) { socket.sendEvent( type, content ); } } /** * @Title: startServer * @Description: 啓動服務 */ public void startServer() { if( socketIOServer == null ) { new Thread( new Runnable() { @Override public void run() { startSocketio(); } } ).start(); } } /** * @Title: stopSocketio * @Description: 中止服務 */ public void stopSocketio() { if( socketIOServer != null ) { socketIOServer.stop(); socketIOServer = null; } } }
3)監聽器啓動(運行於整個項目運行時週期:init-destoryed)jquery
@Configuration @WebListener public class SocketioLisener implements ServletContextListener { @Override public void contextInitialized(ServletContextEvent sce) { //啓動Socketio服務 Socketio socketio = new Socketio(); socketio.startServer(); } @Override public void contextDestroyed(ServletContextEvent sce) { //關閉Socketio服務 Socketio socketio = new Socketio(); socketio.stopSocketio(); } }
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>消息推送</title> </head> <body> </body> <script src="https://code.jquery.com/jquery-3.2.1.min.js"></script> <script type="text/javascript" src="./js/socket.io/socket.io.js"></script> <script type="text/javascript"> <!-- 實時從指定查看是否有消息 --> var socket = io.connect('localhost:9092'); socket.on('connect_msg',function(data){ alert(data); // var personInfo = JSON.parse(data); // console.log(personInfo); }); </script> </html>
… /** * 測試報警推送服務:主要應用一個方法pushArr */ @GetMapping("/pushMessage") @ApiOperation( "測試消息推送" ) public void pushMessage(){ Socketio socketio = new Socketio(); //這裏發送的消息內容能夠結合具體場景自定義對象 socketio.pushArr("connect_msg", "今天下午2點開會"); } …
經過訪問測試服務請求 可看到以下效果:spring
客戶端相關js代碼:client.rarspringboot