IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> 使用websocket监控后台数据 -> 正文阅读

[网络协议]使用websocket监控后台数据

应甲方要求,我们要在页面按频次刷新后台目标数据,当然是首选websocket了,由后台向前端推送数据。前端修改刷新频次时,向后端发送数据。类似RabbitMQ管理后台自动刷新。

在这里插入图片描述

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-websocket</artifactId>
    <version>2.1.10.RELEASE</version>
</dependency>
@Configuration
public class WebSocketConfig {
	@Bean
	public ServerEndpointExporter serverEndpointExporter() {
	    return new ServerEndpointExporter();
	}
}

代码已简化,默认每秒刷新一次,有客户端接入时,开始推送数据。

@ServerEndpoint("/websocket/monitor")
@Component
public class MyServerEndPoint {
    @OnOpen
    public void onOpen(Session session) {
        sessionMap.put(session.getId(), session);
        sessionMapSleep.put(session.getId(), 1);
        executorService.submit(() -> {
            while (null != sessionMap.get(session.getId())) {
                try {
                    session.getBasicRemote().sendText("monitor: " + DateHelper.getTime() + "; random=" + ThreadLocalRandom.current().nextInt(1000));
                    TimeUnit.SECONDS.sleep(sessionMapSleep.get(session.getId()));
                } catch (Exception e) {
                    logger.log(Level.ALL, "websocket monitor send error", e);
                }
            }
        });
    }
}

最后来个涂鸦的html,刷新频次没有使用下拉,也没有使用raddio,鬼使神差的用了checkbox。
在这里插入图片描述
页面比较简单,贴一下部分关键代码,保留了小黑checkbox反向选择的代码。

<script>
    var socket = new WebSocket("ws://localhost:8787/websocket/monitor");
    socket.onmessage = function (event) {
        $("#msg").append(event.data + '<br/>');
    };
    
    $(function(){
        $("input[name='refresh']").each(function (i){
            $(this).click(function (){
                if(this.checked){
                    //反向选择
                    $("input[name='refresh'][value!="+this.value+"]").each(function(){
                        $(this).prop("checked",false);
                    })
                    //alert(this.value)
                    socket.send(this.value)
                }
            })
        });
    });
</script>
  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-10-13 11:46:20  更:2021-10-13 11:46:59 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/18 9:37:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码