RabbitMQ插件详解:rabbitmq_web_stomp【RabbitMQ 六】

news2024/12/23 13:17:59

欢迎来到我的博客,代码的世界里,每一行都是一个故事


在这里插入图片描述

《RabbitMQ Web STOMP:打破界限的消息传递之舞》

    • 前言
    • STOMP协议简介
      • STOMP(Simple Text Oriented Messaging Protocol)协议简介
      • STOMP与WebSocket的关系
    • WebSocket和RabbitMQ
      • WebSocket在现代Web应用中的作用
      • RabbitMQ中支持WebSocket的意义
    • 安装和配置rabbitmq_web_stomp插件
      • 安装步骤:
      • 配置 RabbitMQ 以支持 Web STOMP:
    • RabbitMQ Web STOMP插件的作用和优势
      • 1. 实现实时双向通信
      • 2. 轻松集成到Web应用
      • 3. 解决浏览器同源策略限制
      • 4. 支持异构系统集成
      • 5. 提升用户体验
      • 6. 灵活的消息传递模式
    • 适用场景
    • websockt可以实现,为啥还要引入这个?
    • 实现实时消息传递
      • 使用 JavaScript 客户端连接到 Web STOMP:
      • 发布消息:
      • 订阅消息:
    • 应用场景:即时聊天
      • 多用户、多房间的即时聊天示例:
    • 总结:
    • 结语

前言

RabbitMQ一直是消息传递的先锋,在其众多插件中,rabbitmq_web_stomp无疑是一颗璀璨的明珠。这个插件为我们提供了基于WebSocket的STOMP协议支持,为实现实时、双向通信打开了崭新的可能性。本文将带你进入RabbitMQ Web STOMP的神奇世界,揭开消息传递的新篇章。

STOMP协议简介

STOMP(Simple Text Oriented Messaging Protocol)协议简介

STOMP(Simple Text Oriented Messaging Protocol)是一种用于在应用程序之间进行异步消息传递的简单文本协议。它设计简单、易于实现,是一种基于文本的协议,以简化消息传递的过程。

STOMP协议的特点包括:

  1. 简单性: STOMP协议的设计目标之一是简单性,使其易于实现和使用。

  2. 文本协议: STOMP基于文本,消息以文本形式进行编码,便于人类可读,并使其易于调试。

  3. 协议独立性: STOMP协议是协议独立的,它可以在多种底层传输协议上运行,例如TCP、WebSocket等。

  4. 异步消息传递: STOMP协议支持异步消息传递,允许客户端和服务器通过消息进行通信。

STOMP与WebSocket的关系

WebSocket是一种全双工通信协议,它在客户端和服务器之间提供了实时的、双向的通信通道。相比之下,STOMP是一种简单的文本协议,专注于异步消息传递。

WebSocket和STOMP可以一起使用,将WebSocket作为底层传输协议,而STOMP作为消息传递的协议。通过这种组合,可以在Web应用程序中实现实时的、异步的消息传递。

WebSocket提供了一个持久化的连接,而STOMP定义了一种消息传递的格式和协议。这种组合在实时Web应用程序、聊天应用、通知系统等场景中非常有用,使得浏览器和服务器能够进行实时的双向通信。通常,WebSocket用于底层通信,而STOMP用于定义消息的格式和语义。

WebSocket和RabbitMQ

WebSocket在现代Web应用中的作用

WebSocket是一种在Web浏览器和服务器之间提供双向通信的协议。相比于传统的HTTP协议,WebSocket在实时性、效率和性能上提供了更好的解决方案。以下是WebSocket在现代Web应用中的一些主要作用:

  1. 实时性: WebSocket允许客户端和服务器之间建立持久性的连接,实现实时双向通信。这使得Web应用程序能够及时推送数据,而不需要客户端轮询服务器。

  2. 双向通信: WebSocket提供了双向通信的能力,客户端和服务器可以同时向对方发送消息。这对于实时协作、聊天应用、实时数据展示等场景非常有用。

  3. 减少网络延迟: 由于WebSocket建立的是持久连接,相比于传统的HTTP请求-响应模型,减少了每次通信都要建立新连接的开销,降低了网络延迟。

  4. 降低服务器负担: WebSocket的持久连接使得服务器不再需要处理大量的短暂连接,降低了服务器的负担,提高了服务器的性能。

  5. 更少的带宽消耗: WebSocket的通信头部相对较小,相比于HTTP请求头,带宽消耗更少,这对于移动设备和带宽有限的网络环境更为重要。

RabbitMQ中支持WebSocket的意义

RabbitMQ是一种消息队列中间件,用于在分布式系统中传递消息。支持WebSocket意味着可以通过WebSocket协议直接连接到RabbitMQ服务器,实现实时的、双向的消息通信。这对于一些特定的应用场景和Web应用程序非常有意义:

  1. 实时通知和更新: 使用WebSocket连接到RabbitMQ,可以实现实时的通知和更新,例如在消息队列中有新消息时,即时推送到客户端,而不需要客户端轮询。

  2. Web应用集成: 对于Web应用程序,通过WebSocket直接连接到RabbitMQ可以简化架构,减少中间层,提高实时性,同时降低服务器的负担。

  3. 即时通讯: 在需要即时通讯的场景中,使用WebSocket连接到RabbitMQ可以提供更快的消息传递速度,实现实时的聊天和消息推送。

  4. WebSockets over AMQP: RabbitMQ也支持通过AMQP(高级消息队列协议)的WebSocket扩展进行通信,这样可以更灵活地与RabbitMQ集成。

综合来说,WebSocket与RabbitMQ的结合使得在分布式系统中更容易实现实时通信和消息传递,为现代Web应用提供更好的用户体验。

安装和配置rabbitmq_web_stomp插件

安装步骤:

  1. 检查 RabbitMQ 版本: RabbitMQ Web STOMP 插件通常需要 RabbitMQ 3.6.0 或更新版本。确保你的 RabbitMQ 版本符合要求。

  2. 开启 RabbitMQ 管理插件: 在开始之前,确保已经安装并启用 RabbitMQ 的管理插件。你可以通过以下命令启用管理插件:

    rabbitmq-plugins enable rabbitmq_management
    

    重启 RabbitMQ 以使更改生效。

  3. 下载插件: RabbitMQ Web STOMP 插件通常是通过 GitHub 上的 RabbitMQ GitHub 仓库获取的。你可以在 https://github.com/rabbitmq/rabbitmq-web-stomp 找到插件的源码和下载说明。

  4. 安装插件: 下载插件后,使用以下命令将其安装到 RabbitMQ 中:

    rabbitmq-plugins enable rabbitmq_web_stomp
    

    这会将 Web STOMP 插件安装到 RabbitMQ。

  5. 重启 RabbitMQ: 在安装插件后,务必重新启动 RabbitMQ 以应用更改:

    service rabbitmq-server restart
    

配置 RabbitMQ 以支持 Web STOMP:

  1. 编辑 RabbitMQ 配置文件: 打开 RabbitMQ 的配置文件,通常位于 /etc/rabbitmq/rabbitmq.config。如果文件不存在,可以手动创建。

    sudo nano /etc/rabbitmq/rabbitmq.config
    
  2. 添加 Web STOMP 配置: 在配置文件中添加 Web STOMP 的配置。以下是一个简单的例子:

    [
      {rabbit, [
        {loopback_users, []}
      ]},
      {rabbitmq_web_stomp, [
        {tcp_listeners, [61613]}
      ]}
    ].
    

    这个例子中,我们允许所有用户连接,监听端口为 61613。

  3. 保存并退出: 保存配置文件并退出编辑器。

  4. 重启 RabbitMQ: 重启 RabbitMQ 以使新配置生效:

    service rabbitmq-server restart
    
  5. 验证配置: 打开 RabbitMQ 管理界面(http://localhost:15672/),登录并导航到 “STOMP Connections” 选项卡。你应该看到 Web STOMP 插件的相关信息。

现在,RabbitMQ 已经配置支持 Web STOMP,并可以通过 WebSocket 连接进行通信。在你的 Web 应用程序中,你可以使用支持 STOMP 协议的客户端库,例如 stompjs,与 RabbitMQ 进行实时通信。

RabbitMQ Web STOMP插件的作用和优势

1. 实现实时双向通信

RabbitMQ Web STOMP插件通过支持STOMP协议和WebSocket技术,使得在分布式系统中实现实时、双向的通信成为可能。传统的消息队列在实时性方面可能存在一定的延迟,而Web STOMP通过WebSocket提供了更快速的消息传递机制,适用于需要即时响应的场景。

2. 轻松集成到Web应用

通过WebSocket和STOMP协议,Web STOMP插件能够轻松地集成到现有的Web应用中。这为开发者提供了一种简单而强大的方式,使得Web应用能够更直接地与RabbitMQ进行通信,实现实时消息的推送和拉取。

3. 解决浏览器同源策略限制

在Web开发中,由于浏览器的同源策略,直接在浏览器中进行跨域的WebSocket连接是有一定限制的。RabbitMQ Web STOMP插件提供了一种通过HTTP握手的方式来建立WebSocket连接的方法,从而绕过了同源策略的限制,使得跨域通信更加便捷。

4. 支持异构系统集成

RabbitMQ作为消息中间件,支持多种编程语言和平台。Web STOMP插件的引入使得不同系统、不同平台之间的实时通信更为灵活,可以轻松实现异构系统之间的集成和消息交互。

5. 提升用户体验

对于需要实时更新的应用场景,如在线聊天、实时监控等,使用RabbitMQ Web STOMP插件能够提升用户体验,使得用户能够更即时地获取到最新的信息,增加应用的实时性和交互性。

6. 灵活的消息传递模式

Web STOMP支持多种消息传递模式,包括点对点的消息推送、订阅-发布模式等,开发者可以根据应用的需求选择最适合的消息传递模式,提高系统的灵活性和可扩展性。

通过这些优势,RabbitMQ Web STOMP插件在实时消息传递领域发挥着重要的作用,解决了一系列与实时通信相关的痛点,为开发者提供了更强大的工具来构建实时性强、高度互动的Web应用。

适用场景

RabbitMQ Web STOMP插件通常在需要实现实时双向通信、提升用户体验以及解决一些特定场景下的痛点时使用。以下是一些典型的应用场景:

  1. 即时聊天应用:

    • RabbitMQ Web STOMP插件适用于构建在线聊天应用,实现用户之间的实时消息传递。通过WebSocket技术,可以使得聊天消息的推送更加实时,提高用户聊天体验。
  2. 实时监控与通知:

    • 在需要实时监控系统状态、告警通知的场景中,Web STOMP插件可以作为可靠的消息传递机制。系统状态变化或者告警事件发生时,通过Web STOMP插件可以及时地将消息推送给相关的用户或监控系统。
  3. 在线协作与编辑:

    • 对于需要多人在线协作编辑的场景,Web STOMP插件可以用于实现实时的文档同步。多个用户在编辑同一个文档时,可以通过Web STOMP插件实时地同步各自的编辑内容,提高协作效率。
  4. 股票行情和金融数据推送:

    • 在金融领域,特别是股票行情和实时金融数据的推送场景中,Web STOMP插件可以用于将实时的市场数据快速推送给客户端,使得投资者能够及时获取到最新的行情信息。
  5. 在线游戏:

    • 在在线游戏中,Web STOMP插件可以作为实时消息传递的工具,用于处理玩家之间的交互、游戏状态的同步等。通过WebSocket技术,可以降低消息传递的延迟,提升游戏的实时性。
  6. 物联网应用:

    • 在物联网场景下,需要设备之间实时通信,例如传感器数据的实时传输、设备状态的监控等。Web STOMP插件可以作为可靠的消息传递中间件,支持设备之间的实时通信。

总体而言,当应用场景需要实现实时消息传递、即时通信以及提升用户体验时,RabbitMQ Web STOMP插件就成为一个强大而合适的选择。

websockt可以实现,为啥还要引入这个?

确实,WebSocket本身已经提供了实时双向通信的能力,而且在很多场景下,直接使用WebSocket就足够满足需求。然而,引入RabbitMQ及其Web STOMP插件的原因主要有以下几点:

  1. 消息队列的优势:
    RabbitMQ是一款强大的消息队列系统,具有高度可靠性、持久性、消息确认和队列管理等特性。在一些复杂的应用场景中,使用消息队列能够更好地处理消息的分发、路由和持久化等问题。

  2. 解耦和可扩展性:
    RabbitMQ作为消息中间件,提供了一种解耦应用组件的方式。通过引入消息队列,不同的应用组件可以独立工作,相互之间通过消息进行通信,从而提高系统的可扩展性和灵活性。

  3. 消息的持久化:
    RabbitMQ支持消息的持久化,即使在生产者将消息发送到队列后,即使消费者当前不在线,消息也会被保留。这对于一些重要的通知和数据同步场景非常重要。

  4. 消息过滤和路由:
    RabbitMQ提供了灵活的消息过滤和路由机制,能够根据消息的属性、内容等进行灵活的路由和过滤。这使得消息可以有选择性地发送到特定的队列,满足不同场景的需求。

  5. 整合现有系统:
    在已有的系统中引入RabbitMQ,能够更容易地整合现有的应用,而不需要大规模地改动现有代码。Web STOMP插件作为RabbitMQ的一部分,提供了轻量级、基于WebSocket的实时通信机制,是现代化应用的一部分。

总体来说,引入RabbitMQ及其Web STOMP插件的决策取决于具体的业务需求和系统架构。在一些复杂的分布式系统中,消息队列的优势可能更为明显。在一些简单的应用中,直接使用WebSocket可能已经足够。选择合适的技术栈需要综合考虑系统的特点和未来的发展方向。

实现实时消息传递

要实现实时消息传递,你可以使用 JavaScript 客户端连接到 RabbitMQ 的 Web STOMP 插件。以下是连接到 Web STOMP、发布消息和订阅消息的基本操作。

使用 JavaScript 客户端连接到 Web STOMP:

  1. 引入 stompjs 库: 在你的项目中引入 stompjs 库,你可以通过 CDN 或包管理工具安装:

    <!-- 使用 CDN 引入 stompjs -->
    <script src="https://cdn.jsdelivr.net/npm/@stomp/stompjs"></script>
    

    或者通过 npm 安装:

    npm install @stomp/stompjs
    
  2. 创建连接: 在你的 JavaScript 代码中创建一个连接到 RabbitMQ 的 Web STOMP 的客户端:

    const client = new StompJs.Client({
      brokerURL: 'ws://your-rabbitmq-server:15674/ws',
      connectHeaders: {
        login: 'your-username',
        passcode: 'your-password',
      },
      debug: function (str) {
        console.log(str);
      },
      reconnectDelay: 5000,
      heartbeatIncoming: 4000,
      heartbeatOutgoing: 4000,
    });
    

    请替换 your-rabbitmq-server, your-username, 和 your-password 为实际的 RabbitMQ 服务器地址、用户名和密码。

  3. 连接到 RabbitMQ: 使用 client.activate() 连接到 RabbitMQ:

    client.activate();
    

    这将激活连接,并开始监听消息。

发布消息:

// 定义消息内容
const message = { text: 'Hello, RabbitMQ!' };

// 发布消息到指定的队列
client.publish({ destination: '/exchange/your-exchange-name/your-routing-key', body: JSON.stringify(message) });

请将 your-exchange-name 替换为实际的交换机名称,your-routing-key 替换为实际的路由键。

订阅消息:

// 订阅消息
const subscription = client.subscribe('/exchange/your-exchange-name/your-routing-key', (message) => {
  console.log('Received message:', JSON.parse(message.body));
});

// 在需要取消订阅时执行
// subscription.unsubscribe();

同样,将 your-exchange-name 替换为实际的交换机名称,your-routing-key 替换为实际的路由键。

通过这些基本操作,你可以在 JavaScript 客户端实现连接到 RabbitMQ 的 Web STOMP,发布消息和订阅消息,实现实时消息传递。在实际项目中,你可能需要更多的错误处理和其他功能,这取决于你的应用程序需求。

应用场景:即时聊天

实现即时聊天功能涉及到多用户和多房间的管理,通过 Web STOMP 连接到 RabbitMQ 可以为实时聊天提供强大的消息传递基础。以下是一个简单的实时聊天的例子,包括多用户和多房间的实现方式。

多用户、多房间的即时聊天示例:

  1. 前端代码: 使用 stompjs 库连接到 RabbitMQ 的 Web STOMP 并处理聊天消息。

    <script src="https://cdn.jsdelivr.net/npm/@stomp/stompjs"></script>
    
    <script>
      const username = prompt('Enter your username:'); // 用户输入用户名
    
      const client = new StompJs.Client({
        brokerURL: 'ws://your-rabbitmq-server:15674/ws',
        connectHeaders: {
          login: 'your-username',
          passcode: 'your-password',
        },
      });
    
      client.onConnect = () => {
        // 连接成功,订阅消息
        client.subscribe('/exchange/chat/global', (message) => {
          const msg = JSON.parse(message.body);
          displayMessage(msg.username, msg.text);
        });
      };
    
      client.activate();
    
      function sendMessage() {
        const message = document.getElementById('message').value;
        client.publish({
          destination: '/exchange/chat/global',
          body: JSON.stringify({ username, text: message }),
        });
        document.getElementById('message').value = '';
      }
    
      function displayMessage(sender, text) {
        const chatArea = document.getElementById('chat-area');
        const messageElement = document.createElement('p');
        messageElement.textContent = `${sender}: ${text}`;
        chatArea.appendChild(messageElement);
      }
    </script>
    
  2. 后端代码: 使用任意后端语言实现 WebSocket 服务,将聊天消息转发给 RabbitMQ。

    # 以 Python Tornado 框架为例
    
    import tornado.ioloop
    import tornado.web
    import tornado.websocket
    import pika
    
    class ChatHandler(tornado.websocket.WebSocketHandler):
        def open(self):
            print('WebSocket opened')
    
        def on_message(self, message):
            # 将接收到的消息发送到 RabbitMQ
            connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
            channel = connection.channel()
            channel.basic_publish(exchange='chat', routing_key='global', body=message)
            connection.close()
    
    app = tornado.web.Application([
        (r'/chat', ChatHandler),
    ])
    
    if __name__ == '__main__':
        app.listen(8888)
        tornado.ioloop.IOLoop.current().start()
    
  3. RabbitMQ 配置: 配置 RabbitMQ 以支持多用户和多房间的聊天。

    [
      {rabbit, [
        {loopback_users, []}
      ]},
      {rabbitmq_web_stomp, [
        {tcp_listeners, [61613]}
      ]}
    ].
    
  4. 多用户、多房间支持: 在实际应用中,可以通过在前端界面中提供选择用户和房间的功能,根据用户和房间发送和接收消息。

这个示例演示了一个简单的即时聊天功能,连接到 RabbitMQ 的 Web STOMP 实现实时消息传递。在实际应用中,你可能需要更多的功能,例如用户管理、房间管理、消息历史记录等,这取决于你的应用需求。

总结:

通过学习本文,你将深入了解RabbitMQ中rabbitmq_web_stomp插件的精髓。从协议基础到实际应用,我们一起揭示了这个插件的神奇之处。无论你是新手还是有经验的开发者,RabbitMQ Web STOMP都将为你带来更灵活、高效的消息传递解决方案。让我们一同跳进这场打破界限的消息传递之舞吧!

结语

深深感谢你阅读完整篇文章,希望你从中获得了些许收获。如果觉得有价值,欢迎点赞、收藏,并关注我的更新,期待与你共同分享更多技术与思考。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1313438.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

云原生之深入解析Kubernetes中服务的性能

一、Pyroscope 简介 ① 什么是 Pyroscope&#xff1f; 开发人员通常需要查看生产应用程序中的性能瓶颈以确定问题的原因&#xff0c;为此通常需要可以通过日志和代码工具收集的信息。不幸的是&#xff0c;这种方法通常很耗时&#xff0c;并且不能提供有关潜在问题的足够详细信…

PR模板,漂亮的文字帖子视频模板,方形标题PR项目工程文件下载

Premiere Pro模板&#xff0c;具有6个方形设计PR视频帖子标题文字PR项目工程文件。使用附带的颜色控制器调整和修改颜色&#xff0c;与您自己的品牌相匹配。使用这些效果来增强视频画面。包括视频教程。 适用软件&#xff1a;PR2019 | 分辨率&#xff1a;10801080&#xff08;方…

Android APP 常见概念与 adb 命令

adb 的概念 adb 即 Android Debug Bridge 。在窗口输入 adb 即可显示帮助文档。adb 实际上就是在后台开启一个 server&#xff0c;会接收 adb 的命令然后帮助管理&#xff0c;控制&#xff0c;查看设备的状态、信息等&#xff0c;是开发、测试 Android 相关程序的最常用手段。…

第P7周:咖啡豆识别(VGG-16复现)

>- **&#x1f368; 本文为[&#x1f517;365天深度学习训练营](https://mp.weixin.qq.com/s/rbOOmire8OocQ90QM78DRA) 中的学习记录博客** >- **&#x1f356; 原作者&#xff1a;[K同学啊 | 接辅导、项目定制](https://mtyjkh.blog.csdn.net/)** 一、前期工作 import …

Linux 常用命令----mktemp 命令

文章目录 基本用法实例演示高级用法注意事项 mktemp 命令用于创建一个临时文件或目录&#xff0c;这在需要处理临时数据或进行安全性测试时非常有用。使用 mktemp 可以保证文件名的唯一性&#xff0c;避免因文件名冲突而导致的问题。 基本用法 创建临时文件: 命令 mktemp 默认…

【IC验证】perl脚本——分析前/后仿用例回归情况

目录 1 脚本名称 2 脚本使用说明 3 nocare_list文件示例 4 脚本执行方法 5 postsim_result.log文件示例 6 脚本代码 1 脚本名称 post_analysis 2 脚本使用说明 help&#xff1a;打印脚本说明信息 命令&#xff1a;post_analysis help 前/后仿结束后&#xff0c;首先填…

餐饮品牌小红书探店怎么做?建议收藏

对于餐饮行业来说&#xff0c;消费者的口味和选择越来越多样化&#xff0c;如何在众多竞争者中脱颖而出&#xff0c;成为消费者的心头好&#xff0c;探店活动便应运而生。小红书作为国内知名的社交电商平台&#xff0c;拥有庞大的用户群体&#xff0c;特别是年轻人和美食爱好者…

多域名https证书购买选择

多域名https证书是一种特殊的SSL证书&#xff0c;它允许一个证书同时保护多个域名&#xff0c;并且不限制域名的类型&#xff0c;可以保护多个域名和子域名&#xff0c;确保网站传输信息时不被窃取、篡改。那么我们该怎么选择符合需求的多域名https证书呢&#xff1f;今天就随S…

Python神器:快速删除文本文件中指定行的方法

1. 简介 文件操作是编程中的重要方面。Python作为强大的编程语言&#xff0c;提供了处理文件的能力。删除特定行是文件处理中常见的需求。 2. 打开文件和读取内容 当打开文件并读取其内容时&#xff0c;open()函数和with语句是Python中常用的工具。以下是展示如何使用它们的…

由@EnableWebMvc注解引发的Jackson解析异常

同事合了代码到开发分支&#xff0c;并没有涉及到改动的类却报错。错误信息如下&#xff1a; Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.springframework.http.conv…

第1章:企业级研发测试流程

通过实际&#xff08;自研互联网&#xff09;企业的研发流程一览图。 我们发现分为9个阶段&#xff0c;当然每个公司细节并不一样。 所以我希望你能理解这句话&#xff1a; 一切的流程、行为、结果都是围绕“产品质量”这4个字开展活动。而作为测试&#xff0c;你该考虑的是如何…

数据结构与算法—查找算法(线性查找、二分查找、插值查找、斐波那契查找)

查找算法 文章目录 查找算法1. 线性查找算法2. 二分查找算法2.1 二分查找思路分析2.2 应用实例 3. 插值查找3.1 基本原理3.2 应用实例 4. 斐波那契4.1 基本原理4.2 应用实例 5. 查找总结 在java中&#xff0c;常用的查找有四种&#xff1a; 顺序(线性)查找二分查找/折半查找插值…

JS基本语法

JS基本语法 变量数据类型原始数据类型 函数定义第一种方式第二种方式 JS 对象ArrayStringJavaScript 自定义对象JSONDOMBOM JS 事件事件监听事件绑定常见事件 变量 数据类型 原始数据类型 函数定义 第一种方式 第二种方式 JS 对象 Array String JavaScript 自定义对象 JSON …

2023版本QT学习记录 -2- 标准文件对话框

头文件的使用 #include "QFileDialog"函数原型 getOpenFileName效果 参数 未完待续

电阻的运用

本文引注 https://baijiahao.baidu.com/s?id1749115196647029942&wfrspider&forpc 一、零欧电阻 在电子电路设计时经常用到的一种元件就是电阻&#xff0c;我们都知道电阻在电路中起到分压限流的作用。然而&#xff0c;实际使用时会用到一种特殊的电阻&#xff1a;零…

3ds max软件中的一些常用功能分享!

3ds max软件有很多小伙伴反馈说&#xff0c;明明有很多3ds max教程资料。却不知道如何入门3dmax。 掌握3dmax基本功能是开始使用3dmax的基础之一&#xff0c;所以&#xff0c;小编带大家盘点一下3dmax常用操作。 3dmax常用功能介绍如下&#xff0c;快快跟着小编一起看起来。 1…

[渗透测试学习] Codify - HackTheBox

首先nmap扫描端口 nmap -sV -sC -p- -v --min-rate 1000 10.10.11.239扫出来三个端口&#xff0c;22端口为ssh服务&#xff0c;80端口有http服务&#xff0c;3000端口为nodejs框架 尝试访问下80端口&#xff0c;发现页面重定向 将该域名添加到hosts里 sudo vim /etc/hosts 成…

优先考虑泛型

Java中的泛型&#xff08;Generics&#xff09;提供了一种参数化类型的机制&#xff0c;使得你可以编写更灵活、类型安全的代码。下面是一个例子&#xff0c;说明在Java中优先考虑泛型的好处&#xff1a; 考虑一个简单的容器类&#xff0c;它可以存储任意类型的元素&#xff0…

三种好用的在线色彩提取工具

#三种好用的在线色彩提取工具 1.ecjson网站 网址: https://www.ecjson.com/image_color#b1cfea 或点击链接&#xff1a; ecjson在线色彩提取 图1 ecjson网站色彩提取举例 2.微查网 网址&#xff1a;http://zxqsq.wiicha.com/ 或点击链接&#xff1a; 微查网在线色彩提取 …

JaveEE:手动实现定时器精讲

前言 在Java并发编程学习中&#xff0c;定时器是必不可少的环节。 我们知道线程的调度是随机的&#xff0c;但是有的时候我们就是需要它有序一些&#xff0c;此时的定时器就可以很好的解决这个问题。它可以按照一定的先后顺序&#xff0c;将我们的任务依次执行。 目录 一.Java官…