MQTT HMACSHA256加密

时间: 2023-10-16 20:05:48 浏览: 26
MQTT支持使用HMAC-SHA256算法进行消息加密。HMAC-SHA256是一种基于哈希函数和密钥的消息认证码算法,能够提供消息完整性和认证性。 MQTT客户端和服务器之间的通信可以使用HMAC-SHA256算法进行加密。在使用该算法之前,需要先通过安全的方式将密钥共享给客户端和服务器。 使用HMAC-SHA256算法进行消息加密的步骤如下: 1. 在MQTT连接时,客户端向服务器发送CONNECT消息,其中包含客户端ID和其他连接参数。 2. 服务器向客户端发送CONNACK消息,其中包含连接状态码和其他连接参数。 3. 在连接建立之后,客户端和服务器之间的所有消息都需要进行加密。 4. 客户端将要发送的消息使用HMAC-SHA256算法进行加密,并将密文作为消息体发送给服务器。 5. 服务器接收到密文后,使用相同的密钥和算法进行解密,验证消息的完整性和认证性。 6. 如果消息验证通过,则服务器向客户端发送相应的响应消息;如果消息验证失败,则服务器将拒绝该消息并向客户端发送错误响应消息。 总之,MQTT HMAC-SHA256加密提供了一种安全的通信方式,能够保护消息的机密性、完整性和认证性。
相关问题

MQTT 加密的话 端口变么

MQTT 加密通常使用的是 SSL/TLS 协议,因此需要使用另一个端口号来提供加密服务。默认情况下,非加密的 MQTT 服务使用的是 1883 端口,而加密的 MQTT 服务使用的是 8883 端口。这个端口号可以在 MQTT 服务器的配置文件中进行修改。 如果你使用的是 Mosquitto MQTT 服务器,你可以在配置文件中找到以下行: ``` # Port to use for the encrypted MQTT protocol. #port 8883 ``` 将 `port` 行的注释符号 `#` 去掉,并将端口号改为你想要的加密端口号即可。修改完成后,需要重新启动 Mosquitto 服务器才能生效。

windows c语言使用mqtt不加密向mosquitto服务器推送json数据

在 Windows C 语言程序中使用 MQTT 协议向 Mosquitto 服务器发送 JSON 数据,可以使用 Paho MQTT C 客户端库。下面是一个简单的示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <MQTTClient.h> #include <cJSON.h> #define ADDRESS "tcp://10.10.10.97:1883" #define CLIENTID "ExampleClientPub" #define TOPIC "test" #define QOS 1 #define TIMEOUT 10000L int main(int argc, char* argv[]) { MQTTClient client; MQTTClient_connectOptions conn_opts = MQTTClient_connectOptions_initializer; cJSON *root = NULL; char *payload = NULL; int rc; MQTTClient_create(&client, ADDRESS, CLIENTID, MQTTCLIENT_PERSISTENCE_NONE, NULL); conn_opts.keepAliveInterval = 20; conn_opts.cleansession = 1; if ((rc = MQTTClient_connect(client, &conn_opts)) != MQTTCLIENT_SUCCESS) { printf("Failed to connect, return code %d\n", rc); exit(EXIT_FAILURE); } root = cJSON_CreateObject(); cJSON_AddStringToObject(root, "name", "John"); cJSON_AddStringToObject(root, "surname", "Doe"); cJSON_AddNumberToObject(root, "age", 30); payload = cJSON_Print(root); MQTTClient_message pubmsg = MQTTClient_message_initializer; pubmsg.payload = payload; pubmsg.payloadlen = strlen(payload); pubmsg.qos = QOS; pubmsg.retained = 0; MQTTClient_deliveryToken token; MQTTClient_publishMessage(client, TOPIC, &pubmsg, &token); printf("Waiting for up to %d seconds for publication of %s\n" "on topic %s for client with ClientID: %s\n", (int)(TIMEOUT / 1000), payload, TOPIC, CLIENTID); rc = MQTTClient_waitForCompletion(client, token, TIMEOUT); printf("Message with delivery token %d delivered\n", token); cJSON_Delete(root); free(payload); MQTTClient_disconnect(client, 10000); MQTTClient_destroy(&client); return rc; } ``` 这个示例代码中,首先定义了一些常量,包括 MQTT 代理服务器的地址 `ADDRESS`、客户端 ID `CLIENTID`、MQTT 主题 `TOPIC`、消息 QoS 级别 `QOS`、和超时时间 `TIMEOUT`。 然后,在 `main` 函数中,创建了一个 MQTT 客户端实例 `client`。使用 `MQTTClient_connect` 函数连接 MQTT 代理服务器。连接成功后,使用 cJSON 库创建了一个 JSON 对象 `root`,并向其中添加了三个属性:`name`、`surname` 和 `age`。使用 `cJSON_Print` 函数将 JSON 对象转换成字符串格式,保存在变量 `payload` 中。 接着,定义了一个 MQTT 消息结构体 `pubmsg`,并设置了消息内容为 `payload`、消息长度为字符串长度、QoS 级别为 1,保留标志为 0。使用 `MQTTClient_publishMessage` 函数将消息发布到指定的 MQTT 主题上,并获取了发布令牌 `token`。 等待消息发布完成,使用 `MQTTClient_waitForCompletion` 函数等待消息传递完成,超时时间为 `TIMEOUT`。如果消息成功发送,则打印消息传递令牌 `token`。 最后,释放 JSON 对象内存、释放字符串内存、断开 MQTT 连接并销毁 MQTT 客户端实例,然后返回程序执行结果。 请注意,这个示例代码中的 MQTT 连接是不加密的,如果需要加密,请使用 SSL/TLS 协议连接 Mosquitto 服务器。

相关推荐

最新推荐

recommend-type

虚拟机Centos7搭建MQTT服务

【初学者福利】虚拟机Centos7搭建MQTT服务。【注:虚拟机可连接互联网;以下指令依次进行即可】第二章附带JAVA代码。
recommend-type

WIndows下超详细的QtMqtt编译配置教程

WIndows下超详细的QtMqtt编译配置教程,包含了QtMqtt源码下载、编译配置、QtMqtt帮助手册生成配置。
recommend-type

Docker MQTT安装使用教程

今天小编就为大家分享一篇关于Docker MQTT安装使用教程,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
recommend-type

MQTT协议中文版 pdf 文档下载

MQTT协议中文版 本规范分为七个章节: 第一章 – 介绍 第二章 – MQTT控制报文格式 第三章 – MQTT控制报文 第四章 – 操作行为 第五章 – 安全 第六章 – 使用WebSocket 第七章 – 一致性目标 附录B – 强制性规范...
recommend-type

Kepware IOT gateway使用教程 - MQTT Client

Kepware中IOT gateway模块功能下MQTT具体使用方法,过程很详细,有详细的图形指引,对研究Kepware通过MQTT和其他Client数据交互很有价值,希望对初入IOT的朋友有很好的帮助
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【实战演练】MATLAB用遗传算法改进粒子群GA-PSO算法

![MATLAB智能算法合集](https://static.fuxi.netease.com/fuxi-official/web/20221101/83f465753fd49c41536a5640367d4340.jpg) # 2.1 遗传算法的原理和实现 遗传算法(GA)是一种受生物进化过程启发的优化算法。它通过模拟自然选择和遗传机制来搜索最优解。 **2.1.1 遗传算法的编码和解码** 编码是将问题空间中的解表示为二进制字符串或其他数据结构的过程。解码是将编码的解转换为问题空间中的实际解的过程。常见的编码方法包括二进制编码、实数编码和树形编码。 **2.1.2 遗传算法的交叉和
recommend-type

openstack的20种接口有哪些

以下是OpenStack的20种API接口: 1. Identity (Keystone) API 2. Compute (Nova) API 3. Networking (Neutron) API 4. Block Storage (Cinder) API 5. Object Storage (Swift) API 6. Image (Glance) API 7. Telemetry (Ceilometer) API 8. Orchestration (Heat) API 9. Database (Trove) API 10. Bare Metal (Ironic) API 11. DNS
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。