springBoot 实现 webSocket消息推送

首先在页面中输入如下代码:

一:前端代码

<script>
var websocket = null;
if('Websocket' in window) {
    websocket = new WebSocket('ws://这里是你想实现的页面地址');  
}else{
    alert('该浏览器不支持websocket');
}
websocket.onopen = function (event) {
    console.log('建立连接');
}
websocket.onclose = function (event) {
    // body...
    console.log('连接关闭');
}
websocket.onmessage = function(event){
    console.log('收到消息:' + event.data);
}
websocket.onerror = function(){
    alert('websocket通信发生错误');
}
window.onbeforeunload = function(){
    websocket.close();
}
</script>

二:在项目maven引入依赖:

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-websocket</artifactId>
		</dependency>

2.1 新建一个配置类

@Component
public class WebSocketConfig {
    public ServerEndpointExporter serverEndpointExporter(){
        return new ServerEndpointExporter();
    }
}

三.使用

@Component
@ServerEndpoint("/webSocket")
@Slf4j
public class WebSocket {
    private Session session;
    private static CopyOnWriteArraySet<WebSocket> webSockets = new CopyOnWriteArraySet<>();
    @OnOpen
    public void onOpen(Session session){
        this.session = session;
        webSockets.add(this);
        log.info("【websocket消息】有新的连接,总数:{}",webSockets.size());
    }

    @OnClose
    public void onClose(){
        webSockets.remove(this);
        log.info("【websocket消息】连接断开,总数:{}",webSockets.size());
    }

    @OnMessage
    public void onMessage(String message){
        log.info("【websocket消息】收到客户端发来的消息{}",message);
    }

    public void sendMessage(String message){
        for (WebSocket webSocket : webSockets){
            log.info("【websocket消息】广播消息 message{}",message);
            try {
                webSocket.session.getBasicRemote().sendText(message);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}

3.1 当登录你刚刚生成的 script 代码的页面时候,出现如下;正是对应前端script中的建立连接。

springBoot 实现 webSocket消息推送

3.2 生成一个测试推送消息类如下

@Controller
@RequestMapping("/test/")
public class TestController {
    @Autowired
    private WebSocket webSocket;
    @GetMapping("/tests")
    @ResponseBody
    public String tests(){
        webSocket.sendMessage("这是测试消息推送功能");
        return "this is test";
    }
}

3.3登录此页面之后

springBoot 实现 webSocket消息推送

这是接收页面的提醒

springBoot 实现 webSocket消息推送

当信息可以传送到前端页面的时候,等同于 你想实现什么方式提醒都可以,比如,弹窗。。

 

上一篇:黑客是如何攻击 WebSockets 和 Socket.io的


下一篇:每个开发人员都应该知道的WebSockets知识