教育行業(yè)A股IPO第一股(股票代碼 003032)

全國咨詢/投訴熱線:400-618-4000

EMQ X支持哪些認證方式?

更新時間:2023年08月03日17時58分 來源:傳智教育 瀏覽次數(shù):

好口碑IT培訓

EMQ X 中的認證指的是當一個客戶端連接到 EMQ X 的時候,通過服務器端的配置來控制客戶端連接服務器的權限。

EMQ X 的認證支持包括兩個層面:

MQTT 協(xié)議本身在 CONNECT 報文中指定用戶名和密碼,EMQ X 以插件形式支持基于 Username、 ClientID、HTTP、JWT、LDAP 及各類數(shù)據(jù)庫如 MongoDB、MySQL、PostgreSQL、Redis 等多種形式的認證。

在傳輸層上,TLS 可以保證使用客戶端證書的客戶端到服務器的身份驗證,并確保服務器向客戶端驗證服務器證書。也支持基于 PSK 的 TLS/DTLS 認證。

認證方式

EMQ X 支持使用內置數(shù)據(jù)源(文件、內置數(shù)據(jù)庫)、JWT、外部主流數(shù)據(jù)庫和自定義 HTTP API 作為身份認證數(shù)據(jù)源。

連接數(shù)據(jù)源、進行認證邏輯通過插件實現(xiàn)的,每個插件對應一種認證方式,使用前需要啟用相應的插件。

客戶端連接時插件通過檢查其 username/clientid 和 password 是否與指定數(shù)據(jù)源的信息一致來實現(xiàn)對客戶端的身份認證。

EMQ X 支持的認證方式:

內置數(shù)據(jù)源

Username 認證

Cliend ID 認證

使用配置文件與 EMQ X 內置數(shù)據(jù)庫提供認證數(shù)據(jù)源,通過 HTTP API 進行管理,足夠簡單輕量。

外部數(shù)據(jù)庫

LDAP 認證

MySQL 認證

PostgreSQL 認證

Redis 認證

MongoDB 認證

外部數(shù)據(jù)庫可以存儲大量數(shù)據(jù),同時方便與外部設備管理系統(tǒng)集成。

其他

HTTP 認證

JWT 認證

JWT 認證可以批量簽發(fā)認證信息,HTTP 認證能夠實現(xiàn)復雜的認證鑒權邏輯。

更改插件配置后需要重啟插件才能生效,部分認證鑒權插件包含 ACL 功能

認證結果

任何一種認證方式最終都會返回一個結果:

認證成功:經(jīng)過比對客戶端認證成功

認證失敗:經(jīng)過比對客戶端認證失敗,數(shù)據(jù)源中密碼與當前密碼不一致

忽略認證(ignore):當前認證方式中未查找到認證數(shù)據(jù),無法顯式判斷結果是成功還是失敗,交由認證鏈下一認證方式或匿名認證來判斷。

匿名認證

EMQ X 默認配置中啟用了匿名認證,任何客戶端都能接入 EMQ X。沒有啟用認證插件或認證插件沒有顯式允許/拒絕(ignore)連接請求時,EMQ X 將根據(jù)匿名認證啟用情況決定是否允許客戶端連接。

配置匿名認證開關:

# etc/emqx.conf
## Value: true | false
allow_anonymous = true

生產環(huán)境中請禁用匿名認證。

注意:我們需要進入到容器內部修改該配置,然后重啟EMQ X服務。

# 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 認證相同加鹽規(guī)則與哈希方法處理客戶端信息得到密文。

3. 將客戶端信息寫入數(shù)據(jù)庫,客戶端的密碼應當為密文信息。

0 分享到:
和我們在線交談!