EMQ X如何生成认证信息?身份认证流程和操作步骤

news/2024/7/5 3:35:49

身份认证是大多数应用的重要组成部分,EMQ X 中的认证指的是当一个客户端连接到 EMQ X 的时候,通过服务器端的配置来控制客户端连接服务器的权限。

EMQ X 的认证支持包括两个层面:

• MQTT 协议本身在 CONNECT 报文中指定用户名和密码,EMQ X 以插件形式支持基于 Username、

ClientID、HTTP、JWT、LDAP 及各类数据库如 MongoDB、MySQL、PostgreSQL、Redis 等多种形式的认 证。

• 在传输层上,TLS 可以保证使用客户端证书的客户端到服务器的身份验证,并确保服务器向客户端验证服 务器证书。也支持基于 PSK 的 TLS/DTLS 认证。

认证方式

EMQ X 支持使用内置数据源(文件、内置数据库)、JWT、外部主流数据库和自定义 HTTP API 作为身份认证 数据源。

连接数据源、进行认证逻辑通过插件实现的,每个插件对应一种认证方式,使用前需要启用相应的插件。 客户端连接时插件通过检查其 username/clientid 和 password 是否与指定数据源的信息一致来实现对客户端的身份认证。

EMQ X 支持的认证方式:

内置数据源

• Username 认证

• Cliend ID 认证

使用配置文件与 EMQ X 内置数据库提供认证数据源,通过 HTTP API 进行管理,足够简单轻量。

外部数据库

• LDAP 认证

• MySQL 认证

• PostgreSQL 认证

• Redis 认证

• MongoDB 认证

外部数据库可以存储大量数据,同时方便与外部设备管理系统集成。

其他

• HTTP 认证

• JWT 认证

JWT 认证可以批量签发认证信息,HTTP 认证能够实现复杂的认证鉴权逻辑。 更改插件配置后需要重启插件才能生效,部分认证鉴权插件包含 ACL 功能

认证结果

任何一种认证方式最终都会返回一个结果:

认证成功:经过比对客户端认证成功

认证失败:经过比对客户端认证失败,数据源中密码与当前密码不一致忽略认证(ignore):当前认证方式中未查找到认证数据,无法显式判断结果是成功还是失败,交由认 证链下一认证方式或匿名认证来判断

匿名认证

EMQ X 默认配置中启用了匿名认证,任何客户端都能接入 EMQ X。没有启用认证插件或认证插件没有显式允 许/拒绝(ignore)连接请求时,EMQ X 将根据匿名认证启用情况决定是否允许客户端连接。

配置匿名认证开关:

# etc/emqx.conf 

## Value: true | false 
allow_anonymous = true

生产环境中请禁用匿名认证。

注意:我们需要进入到容器内部修改该配置,然后重启EMQ X服务

密码加盐规则与哈希方法

EMQ X 多数认证插件中可以启用哈希方法,数据源中仅保存密码密文,保证数据安全。

启用哈希方法时,用户可以为每个客户端都指定一个 salt(盐)并配置加盐规则,数据库中存储的密码是按照 加盐规则与哈希方法处理后的密文。

以 MySQL 认证为例:

加盐规则与哈希方法配置:

# etc/plugins/emqx_auth_mysql.conf 
## 不加盐,仅做哈希处理 
auth.mysql.password_hash = sha256 
## salt 前缀:使用 sha256 加密 salt + 密码 拼接的字符串 
auth.mysql.password_hash = salt,sha256 
## salt 后缀:使用 sha256 加密 密码 + salt 拼接的字符串 
auth.mysql.password_hash = sha256,salt 
## pbkdf2 with macfun iterations dklen 
## macfun: md4, md5, ripemd160, sha, sha224, sha256, sha384, sha512 
## auth.mysql.password_hash = pbkdf2,sha256,1000,20

生成认证信息时

1. 为每个客户端分用户名、Client ID、密码以及 salt(盐)等信息

2. 使用与 MySQL 认证相同加盐规则与哈希方法处理客户端信息得到密文

3. 将客户端信息写入数据库,客户端的密码应当为密文信息

EMQ X 身份认证流程

1.根据配置的认证 SQL 结合客户端传入的信息,查询出密码(密文)和 salt(盐)等认证数据,没有查询

结果时,认证将终止并返回 ignore 结果

2.根据配置的加盐规则与哈希方法计算得到密文,没有启用哈希方法则跳过此步

3.将数据库中存储的密文与当前客户端计算的到的密文进行比对,比对成功则认证通过,否则认证失败PostgreSQL 认证功能逻辑图:

写入数据的加盐规则、哈希方法与对应插件的配置一致时认证才能正常进行。更改哈希方法会造成现有认证数 据失效。

认证链

当同时启用多个认证方式时,EMQ X 将按照插件开启先后顺序进行链式认证:

一旦认证成功,终止认证链并允许客户端接入。

一旦认证失败,终止认证链并禁止客户端接入。

直到最后一个认证方式仍未通过,根据匿名认证和配置判定:

匿名认证开启时,允许客户端接入

匿名认证关闭时,禁止客户端接入

同时只启用一个认证插件可以提高客户端身份认证效率。

 


http://lihuaxi.xjx100.cn/news/1284960.html

相关文章

SQL Server中的常用函数汇总

前言 总计在SQL server中常用5类的函数:字符串函数,日期函数,数学函数,系统函数,聚合函数,供后续使用 字符串函数 --常用的字符串函数1.charindex() -- 字符索引2.len() -- 长度3.upper() -- 大写…

Promise 深度学习

文章目录 Promise 由来Promise的用法reject的用法finally all的用法race的用法总结 Promise 由来 我们处理异步函数最普通的方法是这样的,等待上一次请求结束再执行下一步操作: // 一般以定时器来模拟一次请求 setTimeout(() > {console.log("…

Kotlin语言介绍并推荐入门书籍(15本)

Kotlin是一种基于JVM(Java Virtual Machine)的静态类型编程语言,由JetBrains开发并于2017年正式发布。它旨在提供一种更简洁、更安全、更实用的替代方案来编写Java应用程序。以下是Kotlin语言的一些主要特点: 1. 与Java互操作性&…

Soybean Admin - 基于 Vue3 / vite3 等最新前端技术栈构建的中后台模板,免费开源、清新优雅,主题丰富

一款专业好看、完成度很高的 admin 开源项目,无论是用于生产还是学习,都非常值得尝试。 关于 Soybean Admin Soybean Admin 是一个基于 Vue3 / Vite3 / TypeScript / NaiveUI / Pinia 和 UnoCSS 的中后台模版,它使用了最新流行的前端技术栈…

TypeScript——类型别名(type)

类型别名 type 关键字,用来给一个类型起个新名字 定义类型别名 type str stringlet s: str 我是张三console.log(s)定义联合类型别名 type item string | numberlet arr: item[] [1, zs]console.log(arr)interface与类型别名 两者可以被继承 interface 继…

模板匹配

模板匹配 模板匹配和卷积原理很像,模板在原图像上从原点开始滑动,计算模板与图像窗口的差异程度,然后将每次计算的结果放入一个矩阵,最后作为结果输出。假设原图像大小为A * B,模板大小为a * b,则输出结果…

Docker 配置 vins-mono

前提条件&#xff1a;物理机上安装好ROS和Docker&#xff0c;参考 http://wiki.ros.org/ROS/Installation Ubuntu Docker 安装 | 菜鸟教程 Docker 换源 sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json <<-EOF {"registry-mirrors": ["镜像…

Rancher集群搭建

前言 随着容器的普及和Kubernetes 的日渐成熟&#xff0c;企业内部运行多个Kubernetes 集群已变得颇为常见&#xff0c;然而部署kubernetes集群的方式也多样化&#xff0c;二进制部署、rancher、kubeadm、minikube等。然而本篇文章主要讲解的是如何使用rancher快速部署一个k8s集…