非常好用的C++跨平台网络通信Mongoose,随笔记录

  1. 简介

        Mongoose 是一个 C/C++ 网络库。它实现了事件驱动, TCP、UDP、HTTP、WebSocket、MQTT 的非阻塞 API。它连接设备 并将它们带到网上。自 2004 年以来,一些开源和商业 产品已经利用了它。它甚至运行在 国际空间站! Mongoose 使嵌入式网络编程变得快速, 坚固且简单。

        Mongoose 适用于 Windows、Linux、Mac 和许多嵌入式架构 如STM32、NXP、TI、ESP32等。它可以在现有的基础上运行 操作系统和 TCP/IP 堆栈(例如 FreeRTOS 和 lwIP)以及裸机上的操作系统和 TCP/IP 堆栈, 利用 Mongoose 的内置 TCP/IP 堆栈和网络驱动程序。

        参考网址:Mongoose :: Documentation

        参考代码:https://github.com/cesanta/mongoose/tree/master

  1. 架构图

        在操作系统环境中,Mongoose 使用 BSD 提供的套接字 API 通过操作系统的 TCP/IP 堆栈:

        在嵌入式裸机环境中,Mongoose可以利用自己内置的 与网络驱动程序堆栈 - 即它可以直接在硬件之上运行:

 

教程和示例#

开发环境#

  • 构建工具 - 设置开发环境以构建和运行 Mongoose 库示例以及开发新应用程序的指南。

网页用户界面#

  • 设备仪表板 - 本教程展示了如何构建设备仪表板的示例,这对于无头设备非常有用。
  • REST 基础知识 - 本教程将向您展示如何实现和使用基于 REST 的用户界面 (UI) 的基础知识。
  • 纯 JavaScript UI - 本教程将向您展示如何通过基于 REST 的后端实现基于 JavaScript 的纯用户界面 (UI)。
  • Preact UI - 本教程将向您展示如何通过基于 REST 的后端为用户界面 (UI) 实现基于 Preact 的前端。我们将在这里重点介绍 Preact UI 前端的基础知识。
  • 用户身份验证 - 本教程将向您展示如何通过基于 REST 的后端使用基于 Preact 的用户界面 (UI) 实现会话登录。我们将在这里重点介绍登录过程的基础知识。
  • 数据推送 - 本教程将向您展示如何将数据从设备推送到浏览器上运行的基于 JavaScript 的用户界面 (UI);使用 WebSocket 或基于 REST 的 API。
  • 嵌入式文件系统 - 本教程展示了如何将所有 Web 文件嵌入到链接到服务器二进制文件的打包文件系统中的示例;形成只读文件系统。
  • MQTT 仪表板 - 本教程展示了如何构建远程设备仪表板的示例,这对于处理远程设备非常有用。

HTTP#

  • HTTP 服务器 - 基本 HTTP 服务器教程将向您展示如何配置 HTTP 服务器,同时您可以熟悉事件管理器和服务器 API。
  • HTTP 客户端 - 本教程将向您展示如何使用 Mongoose 库实现 HTTP 客户端。
  • HTTP 代理客户端 - 本教程将向您展示如何在必须通过代理完成连接的地方使用 Mongoose 作为 HTTP 客户端。
  • HTTP 反向代理 - 本教程将向您展示如何使用 Mongoose 实现反向代理。
  • 文件上传 - 本教程将向您展示如何将文件上传到 Mongoose Web 服务器。
  • 巨大的响应 - 本教程将向您展示如何发送大于可用缓冲区内存的大量数据。
  • 视频流 - 本教程将向您展示如何以一系列 MJPEG 帧的形式发送视频流。

Websocket#

  • Websocket 服务器 - 本教程演示如何使用 Mongoose 库来实现 Websocket 服务器。
  • Websocket 客户端 - 本教程演示如何使用 Mongoose 库来实现 Websocket 客户端。
  • 基于 WS 的 JSON-RPC - 本教程演示如何使用 Mongoose 库通过 WebSocket 实现 JSON-RPC 功能。

MQTT#

  • MQTT 客户端 - 本教程演示如何使用 Mongoose 库来实现 MQTT 客户端。
  • MQTT 服务器 - 本教程演示如何使用 Mongoose 库来实现简单的 MQTT 3.1.1 服务器。
  • 基于 WS 客户端的 MQTT - 本教程演示如何使用 Mongoose 库来实现通过 WebSocket 连接到代理的 MQTT 客户端。
  • AWS IoT - 本教程演示如何使用 Mongoose Library 与 AWS IoT 服务进行通信。
  • MQTT 仪表板 - 本教程展示如何构建 MQTT 控制的无头设备的示例。

SSL/TLS#

  • SSL/TLS - 在本教程中,我们将介绍如何为服务器和客户端启用 SSL/TLS。

固件更新#

  • 固件更新 - 本教程将向您展示如何使用 Mongoose 库函数来实现固件更新。

其他#

  • 错误处理 - 如果连接由于某种原因失败,您可以在本部分找到如何操作的答案。
  • 多线程 - 本教程将向您展示如何在多线程环境中使用 Mongoose。
  • SOCKS5 服务器 - 本教程将向您展示如何使用 Mongoose 库函数来实现基于 TCP 的服务器,在本例中是 SOCKS5 代理服务器。
  • 计时器 - 本教程将指导您配置计时器回调,这是一种执行某些定期操作的机制。
  • TCP 客户端和服务器 - 这个简单的教程演示了如何使用 Mongoose 库来实现 TCP 客户端和服务器,甚至通过 TLS。
  • UART 桥 - 本教程展示如何通过网络发送 UART 数据的示例。
  • SMTP 客户端 - 这个简单的教程演示了如何使用 Mongoose Library 通过 TLS 实现 SMTP 客户端。
  • Mongoose 内置 TCP/IP 堆栈的驱动程序 - 编写您自己的驱动程序,将我们的通用 CMSIS 驱动程序移植到您的 ARM 设备

UDP#

  • 强制 DNS 服务器 - 本教程演示如何使用 Mongoose 库来实现强制 DNS 门户。设备配置通常需要它。
  • SNTP 时间同步 - 本教程将向您展示如何与远程 SNTP 服务器同步时间。
  • SSDP 搜索 - 本教程演示如何通过执行 SSDP 搜索来使用 Mongoose 库进行 UDP 通信。

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

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

相关文章

vscode配置latex环境

vscode配置latex环境 1.安装LaTeX Workshop插件2.配置环境附录 1.安装LaTeX Workshop插件 2.配置环境 按照下图进行操作: 在打开的settings.json中加入如下代码( 每行代码的含义见代码详解 ): "latex-workshop.latex.autoB…

java中实现定时给微信群中发送每日简报

大家好,我是雄雄,欢迎关注微信公众号,雄雄的小课堂。 首先给大家看一下实现的效果: 我这边是定时一早6点多发。 下面是代码: /*** (微信机器人)每天早上6点将国内新闻发送至群中*/GetMapping("/sendNewsPengPa…

pytest_collection_modifyitem对用例进行过滤

pytest_collection_modifyitem在收集完用例后执行,通过此hooks,在conftest.py中可以实现对用例的过滤和重新排序 根据用例标记和执行参数标记用例是否跳过( --headless运行时,并且标记only_headed的用例跳过) def pytest_collec…

uniapp中uni-data-select下拉框组件如何去除边框?

在目录中找到文件夹。 找到下拉框组件文件夹 注释该文件夹以下代码就能实现下拉框不带边框。

Kubernetes (k8s) 快速认知

应用部署方式 传统部署时代 早期的时候,各个组织是在物理服务器上运行应用程序。缺点 资源分配问题: 无法限制在物理服务器中运行的应用程序资源使用 维护成本问题: 部署多个物理机,维护许多物理服务器的成本很高 虚拟化部署时…

vue中如何做单元测试 ,请举例说明

vue中如何做单元测试10. 测试 TestVue Test Utils Vue Test Utils 使用实例 vue-jest 使用 vue-jest 进行 Vue 3 单元测试示例 vue中如何做单元测试 在 Vue 中进行单元测试可以使用 Jest 这样的测试框架,它可以提供丰富的 API 和插件来方便地编写、运行和报告测试…

【QT】QListWidget控件的使用

目录 1.概述 2.QListWidget 类常用的属性和方法 3.QListWidget列表框的信号和槽 4.QListWidget 类常用操作示例 4.1 初始化列表 4.2 插入项 4.3 删除当前项和清空列表 4.4 遍历并选择项 4.5 QListWidgetItem常用信号 5.QListWidget 类简单应用 1.概述 Qt 中用于项 (Item &#…

ctrl+d删除的东西怎么没有在回收站?分享原因及解决方法

“好奇怪哦,我用公司电脑的时候,使用ctrld误删除了一个XLSX格式的文件,回收站里也没有找到怎么回事?请问这样删除的文件能恢复吗?求各位高手指点。感谢~” ——在电脑操作中,CtrlD组合键被广泛应…

微信小程序实现上拉加载分页列表的性能优化

微信小程序实现上拉加载分页列表的性能优化 我们的功能里面有个滚动到底部加载的功能,优化前我们的做法是这样的: 大部分人面对长列表滚动的时候,一开始的处理方式都是这样的,如果数据不多,只有几页可能不会太暴露问题…

Java中23种设计模式

提示:文中有理解不到位的地方,欢迎各位大佬指点批评 文章目录 前言创建型模式(关注对象的创建过程):工厂方法模式(Factory Method)抽象工厂模式(Abstract Factory)建造者…

安全生产隐患排查治理信息化系统软件

安全隐患排查系统实现对重大危险源企业、安全隐患信息的登记、整改、复查、分类和统计。系统涵盖了安全隐患排查整治工作的各项基本内容,实现以安全隐患排查整治业务流为主线,处理流程简洁清晰、快速灵活;以排查整治流程为干线,快…

PyQt6 QToolBar工具栏控件

锋哥原创的PyQt6视频教程: 2024版 PyQt6 Python桌面开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili2024版 PyQt6 Python桌面开发 视频教程(无废话版) 玩命更新中~共计44条视频,包括:2024版 PyQt6 Python桌面开发 视频教程(无废话版…

进程通信知识基础【Linux】——下篇

目录 前文 一,命名管道 创建命名管道 1. getline——c库 2. unlink——系统接口 实践代码 common.hpp client.cpp server.cpp Log.cpp 二,共享内存(system V接口) 1. 创建共享内存 shmget接口 2. 删除共享内存 常见…

Mybatis-plus 跳过全局变量的设置 ignoreQueryFilters

Mybatis-plus 跳过全局变量的设置 忽略全局的查询过滤器QueryUpdate 忽略全局的查询过滤器 在Mybatis-plus中,如果你想在执行某些操作时跳过逻辑删除规则,你可以使用wrapper查询包装器的ignoreQueryFilters方法。这个方法可以让你在执行查询或更新操作时…

推荐使用过很好用的api,含免费次数

IP归属地-IPv4城市级:根据IP地址查询归属地信息,支持到城市级,包含国家、省、市、和运营商等信息。IP归属地-IPv6城市级:根据IP地址(IPv6版本)查询归属地信息,支持到中国大陆地区(不…

程序员必知!依赖倒置原则的实战应用与案例分析

依赖倒置原则(Dependence Inversion Principle,DIP)是一种软件设计原则,它要求高层模块不依赖于低层模块,而是依赖于抽象。同时,抽象不依赖于细节,细节应当依赖于抽象。换言之,要针对…

OpenSSL 3.2.0新增Argon2支持——防GPU暴力攻击

1. 引言 OpenSSL新发布的3.20版本中,引入了一些新特性,包括: post-quantum方法Brainpool曲线QUICArgon2:Argon2 是一种慢哈希函数,在 2015 年获得 Password Hashing Competition 冠军,利用大量内存计算抵…

​springboot代码混淆及反混淆代码工具

目录 介绍 什么是混淆 为什么用混淆? 基础混淆 高级混淆工具 #0x1 ipaguard Tool - springboot混淆工具 ipaguard界面概览 ipaguard启动界面 ipaguard代码混淆界面 资源文件混淆界面 重签名界面 尽管到目前为止,这些工具在将代码清理成我们可…

vue爷孙组件传参v-bind=“$attrs“ v-on=“$listeners“

孙title this.$emit(‘事件名’,要传递的值) // titlemethods: {change(e) {console.log(e, e);this.$emit("sValue", this.sValue, this.options[0].label)}}父 box v-bind“ a t t r s " v − o n " attrs" v-on" attrs"v−…

防抖与节流:Vue中的优化技巧

在Vue开发中,防抖(Debounce)和节流(Throttle)是两种常见的优化技巧。本文将详细介绍这两个概念,并探讨它们在Vue应用中的应用场景和实现方式。 随着前端开发的不断发展,用户交互变得越来越复杂&…