【发布时间】:2014-06-30 10:55:35
【问题描述】:
我想了解在通过 websockets 将 MQTT 代理显示到浏览器时保护 Mosquitto 的最佳方法。根据this blog post,我目前正在将 Lighttpd 用于 websocket 层。
我的用例是单向的。我只需要向浏览器发送消息。因此,我可以使用 ACL 来防止不法分子发布消息。
但是我怎样才能阻止不法分子订阅,或者更好的是,首先建立联系?
我知道我可以使用 ID/pw 进行 MQTT 连接。所以,我猜我的应用服务器可以在用户进行身份验证后将凭据发送到浏览器,然后 Javascript 客户端可以使用这些凭据建立 MQTT/WS 连接。但是,如果我有成千上万的客户,我该如何管理 ID 和密码?还是我应该只拥有一些 ID 并定期回收它们?我应该按照mosquitto-auth-plug 将这一点交给 Redis 或类似的吗?
我想知道是否有更好的方法,通过保护网络服务器层内的连接。 Lighttpd 的mod_secdownload 插件似乎提供了一个模型,通过该模型,可以根据共享机密(保留在服务器端)和时间戳的哈希值动态生成 URL。用户通过身份验证后,应用服务器将向下传递此 URL,然后客户端将使用它建立与 MQTT 代理的连接。一段时间后,该 URL 将过期,Javascript 客户端可以捕获此异常,如果用户仍然通过身份验证,则可以请求新的 WS 连接 URL。这与许多 API 身份验证类似。这里有优点吗?
有没有更好的方法?
谢谢,J。
【问题讨论】:
标签: security authentication lighttpd mqtt mosquitto