EMQX 开启 **MySQL + password_based** 认证

我给你最简单、一步到位、直接能用 的 EMQX + MySQL 密码认证 插入用户SQL,你复制执行就能让大疆机场连接 MQTT。

一、先说结论

EMQX 开启 MySQL + password_based 认证后,往 MySQL 里插入用户只需要一条 INSERT

关键只有 3 个字段:

  • username
  • password
  • salt(留空即可)
  • is_superuser(0 就行)

二、你只需要执行这条 SQL(直接复制)

sql 复制代码
INSERT INTO mqtt_user (username, password, salt, is_superuser)
VALUES ('你的MQTT用户名', '你的MQTT密码', '', 0);

真实可测试例子(大疆机场直接能用)

sql 复制代码
INSERT INTO mqtt_user (username, password, salt, is_superuser)
VALUES ('dock_user_001', 'X9B27sK4pR5zQ3vG7tN1dF8hJ0k001', '', 0);

执行完 → 大疆机场立刻就能用这个账号密码连接 EMQX


三、必须确认 EMQX 配置(和我这个一致才有效)

打开 EMQX 的认证配置:
etc/plugins/emqx_auth_mysql.conf

确保这 3 项配置 和我一样

复制代码
auth.mysql.password_hash = plain
auth.mysql.auth_query = select password from mqtt_user where username = '%u' limit 1
auth.mysql.password_based = on
  • password_hash = plain → 密码明文存储
  • auth_query → 查密码
  • password_based = on → 开启密码认证

这样你直接插入明文密码就能用,最适合大疆机场对接。


四、如果你想批量生成用户(直接运行)

sql 复制代码
-- 生成10个大疆机场可用的MQTT账号
INSERT INTO mqtt_user (username, password, salt, is_superuser)
VALUES
('dock_001', 'pwd_001ABC', '', 0),
('dock_002', 'pwd_002ABC', '', 0),
('dock_003', 'pwd_003ABC', '', 0);

五、验证是否生效

  1. 重启 EMQX 插件
bash 复制代码
emqx_ctl plugins reload emqx_auth_mysql
  1. 用MQTT工具测试连接
  • 地址:你的IP
  • 端口:1883
  • 用户名:dock_user_001
  • 密码:X9B27sK4pR5zQ3vG7tN1dF8hJ0k001

能连上 = 成功


六、超级精简总结

EMQX MySQL 密码认证 =
往 mqtt_user 表插入 username + password 明文即可

不需要加密

不需要salt

不需要复杂配置


相关推荐
苍煜10 分钟前
一篇讲懂分库分表:概念、spirngboot实战
数据库·oracle
梦想画家20 分钟前
PostgreSQL 物化视图实战:从数据固化到智能刷新的全链路指南
数据库·postgresql·物化视图
weoptions23 分钟前
简单sql注入中如何通过简单语句判断注入类型&注入方法
数据库·sql
小短腿的代码世界32 分钟前
Qt数据库编程深度解析:从SQL基础到ORM架构设计
数据库·sql·qt
Database_Cool_1 小时前
在 RDS PostgreSQL 中实现 RaBitQ 量化
数据库·阿里云·ai·postgresql
【心态好不摆烂】1 小时前
MySQL操作库
数据库·mysql
Javatutouhouduan1 小时前
Java小白如何快速玩转Redis?
java·数据库·redis·分布式锁·java面试·后端开发·java程序员
沐言人生1 小时前
React Native 源码分析1——HybridData 机制深度分析
android·react native
程序员陆业聪2 小时前
跨平台框架全景图:Flutter/KMP/KuiKly/RN的2026年格局
android
Lyyaoo.3 小时前
Redisson
数据库·缓存