(iOS)MQTT连接 遗嘱 双向认证1

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了(iOS)MQTT连接 遗嘱 双向认证1相关的知识,希望对你有一定的参考价值。

参考技术A MQTT协议是为大量计算能力有限,且工作在低带宽、不可靠的网络的远程传感器和控制设备通讯而设计的协议,它具有以下主要的几项特性:
1、使用发布/订阅消息模式,提供一对多的消息发布,解除应用程序耦合;
2、对负载内容屏蔽的消息传输;
3、使用 TCP/IP 提供网络连接;
4、有三种消息发布服务质量:
“至多一次”,消息发布完全依赖底层 TCP/IP 网络。会发生消息丢失或重复。这一级别可用于如下情况,环境传感器数据,丢失一次读记录无所谓,因为不久后还会有第二次发送。
“至少一次”,确保消息到达,但消息重复可能会发生。
“只有一次”,确保消息到达一次。这一级别可用于如下情况,在计费系统中,消息重复或丢失会导致不正确的结果。
5、小型传输,开销很小(固定长度的头部是 2 字节),协议交换最小化,以降低网络流量;
6、使用 Last Will 和 Testament 特性通知有关各方客户端异常中断的机制;

首先推荐使用 MQTT-Client-FrameWork ,现在还一直维护,而且有什么问题提issue也有人回答,MQTT-Client-FrameWork 包提供的客户端类有 MQTTSession 和 MQTTSessionManager,建议使用后者维持静态资源,而且已经封装好自动重连等逻辑。初始化时需要传入相关的网络参数。具体如下:

---参数解释---

值为1,服务器需要立刻清理连接状态数据。
(tips:断线重连时 如果为yes,会自动订阅回消息,如果为no,则要手动订阅topic,不然会收不到消息)

双向认证方法:让后台生成 ca.crt 和 client.p12文件(client.p12文件由client.crt和client.key合成) 我使用的是自签证书

1.使用命令行把crt转化为der格式

// 获取服务器返回数据

另外提供一个未封装的session的双向认证方法:

参考:

Mqtt用户认证

http://emqtt.com/docs/v2/guide.html

技术分享图片

 

1默认是匿名认证,不用输入用户名和密码,直接可连接

2如何开启用户名和密码认证模式

2-1关闭匿名认证

在你的MQTT安装目录下,进入文件夹

etc/emq.conf 配置启用匿名认证:

## Allow Anonymous authentication
mqtt.allow_anonymous = true
(如图)
技术分享图片

2-2 设置配置文件

用户名密码认证

基于 MQTT 登录用户名(username)、密码(password)认证。

etc/plugins/emq_auth_username.conf 中配置默认用户:

auth.user.$N.username = admin
auth.user.$N.password = public

启用 emq_auth_username 插件:

./bin/emqttd_ctl plugins load emq_auth_username

使用 ./bin/emqttd_ctl users 命令添加用户:

$ ./bin/emqttd_ctl users add <Username> <Password>

---------------------------------------------------------
技术分享图片

 技术分享图片

 

保存后,开启插件

技术分享图片

最后,每次修改配置文件,需要重启一下MQTT客户端。

当然,使用命令行也可以直接添加新用户,且不用重启MQTT,但是,不会自动写入在配置文件中,不利于以后报备。清楚知道那些用过,哪些没有。


以上是关于(iOS)MQTT连接 遗嘱 双向认证1的主要内容,如果未能解决你的问题,请参考以下文章

MQTT服务-Mosquitto简单安装及TLS双向认证配置

K8s和etcd双向认证

emqx配置ssl/tsl实现双向认证

使用mitmproxy嗅探双向认证ssl链接——嗅探AWS IoT SDK的mqtts

java 建立双向认证 https连接

使用 OpenSSL API 建立安全连接 - 双向认证(精讲)