[11]MQTT mosquitto 双向SSL认证配置方式

原创 2015年05月31日 23:07:16

我们知道,MQTT mosquitto支持单项和双向的SSL认证,在上一节中,我们已经给大家分享了单向的SSL如何配置,在这一节中咱们来看一下双向的SSL认证的配置文件应该如何配置? 那么什么是双向的SSL认证呢?所谓的双向的SSL认证,打个通俗的比方就是,在进行SSL加密通信前,通信的双方(在咱们的例子中是mosquitto服务器端和MQTT客户端(消息的发送或者接收端))需要相互验证各自的证书是否合法。比如,是否是一个合法的CA颁发的等等。

在上一节提到,我们知道启动MQTT mosquitto的时候,可以通过下面的命令

mosquitto [-c config file] [ -d | --daemon ] [-p port number] [-v]

来指定启动的方式,其中,-c 后面跟的是启动mosquitto可以调整的参数,比如是否开启基本认证,端口是什么,SSL单向和双向的认证配置等等。

-d 表示MQTT mosquitto将在后台运行。

-p 代表当前的mosquitto服务实例启动以后,其监听端口号,这个配置的覆盖[-c config file] 指定的配置文件中的端口

-v 代码调试模式(verbose)可以输出更多的信息

假设我们自己已经通过OpenSSL生成了相关的CA证书,和服务器端自签名公钥和私钥,客户端的自签名公钥和私钥。其位置分布存储在:

(1) CA证书的位置

D:\mosquitto\certificates\ca.crt

(2) 服务器端的自签名的公钥的地址

D:\mosquitto\certificates\server.crt

(3) 服务器端的自签名的私钥的地址

D:\mosquitto\certificates\server.key


则其单向的SSL的mosquitto服务器端的配置文件(Configuration)的配置方式如下:

假设下面的配置存储在一个名为D:\mosquitto\twowayssl.conf的文本文件中,

# See also the mosquitto-tls man page.

# At least one of cafile or capath must be defined. They both 
# define methods of accessing the PEM encoded Certificate 
# Authority certificates that have signed your server certificate 
# and that you wish to trust.
# cafile defines the path to a file containing the CA certificates.
# capath defines a directory that will be searched for files
# containing the CA certificates. For capath to work correctly, the
# certificate files must have ".crt" as the file ending and you must run
# "c_rehash <path to capath>" each time you add/remove a certificate.
cafile D:\mosquitto\certificates\ca.crt
#capath

# Path to the PEM encoded server certificate.
certfile D:\mosquitto\certificates\server.crt

# Path to the PEM encoded keyfile.
keyfile D:\mosquitto\certificates\server.key

# This option defines the version of the TLS protocol to use for this listener.
# The default value will always be the highest version that is available for
# the version of openssl that the broker was compiled against. For openssl >=
# 1.0.1 the valid values are tlsv1.2 tlsv1.1 and tlsv1. For openssl < 1.0.1 the
# valid values are tlsv1.
tls_version tlsv1

# By default a TLS enabled listener will operate in a similar fashion to a
# https enabled web server, in that the server has a certificate signed by a CA
# and the client will verify that it is a trusted certificate. The overall aim
# is encryption of the network traffic. By setting require_certificate to true,
# the client must provide a valid certificate in order for the network
# connection to proceed. This allows access to the broker to be controlled
# outside of the mechanisms provided by MQTT.
require_certificate true

# If require_certificate is true, you may set use_identity_as_username to true
# to use the CN value from the client certificate as a username. If this is
# true, the password_file option will not be used for this listener.
use_identity_as_username true


从上面可以看出,双向和单项认证的区别是,除了需要单向SSL认证需要的CA的证书,服务器端的公钥和私钥的证书之外,还需要开启下面的两个开关。</span>

# By default a TLS enabled listener will operate in a similar fashion to a
# https enabled web server, in that the server has a certificate signed by a CA
# and the client will verify that it is a trusted certificate. The overall aim
# is encryption of the network traffic. By setting require_certificate to true,
# the client must provide a valid certificate in order for the network
# connection to proceed. This allows access to the broker to be controlled
# outside of the mechanisms provided by MQTT.
require_certificate true

# If require_certificate is true, you may set use_identity_as_username to true
# to use the CN value from the client certificate as a username. If this is
# true, the password_file option will not be used for this listener.
use_identity_as_username true

则可以通过下面的方式启动mosquitto服务器端的双向的SSL服务。

mosquitto D:\mosquitto\twowayssl.conf -p 1885 -v
版权声明:本文为博主原创文章,未经博主允许不得转载。

智能家居通用管理平台(三)-通信方式和数据结构

 智能家居通用管理平台(三)-通信方式和数据结构 一谈到智能家居设备,特别是智能家电,都默认为他们使用WIFI与移动设备(如智能手机)交互。 确实,这种方式优点很多,速度快、容量大、传输距离...

智能家居无线传感网通用监控协议的设计与实现(1)

目前智能家居领域,主流的硬件设备系统都使用无线自组织网络,如ZigBee,Z-Wave,最新出来的蓝牙-mesh网络,也极有可能进入智能家居通信领域(WIFI单件智能产品,其劣势就不用说了,只能玩玩而...

[12]MQTT mosquitto 单向SSL认证的配置方式

我们知道,MQTT mosquitto支持单向和双向的SSL认证,首先咱们来看一下单项认证的配置文件应该如何配置。所谓的单向SSL证书,指的是,MQTT的客户端访问MQTT的服务器端的时候,如果用到了...

SSL/TLS 双向认证(三) -- ESP8266与mosquitto的MQTT双向认证

ESP8266与mosquitto的MQTT双向认证
  • ustccw
  • ustccw
  • 2017年08月09日 11:29
  • 1115

Tomcat6 配置SSL双向认证通讯

  • 2012年07月25日 10:30
  • 400KB
  • 下载

weblogic11g ssl双向认证

1、先写一个BAT批处理脚本,内容如下: @echo off set SERVER_DN="CN=shouli.zjfda.gov.cn,OU=haichuan,O=zjfda,L=hangzho...

Tomcat配置SSL双向认证

  • 2017年03月23日 11:20
  • 302KB
  • 下载

双向SSL认证配置说明

  • 2013年10月18日 13:28
  • 603KB
  • 下载

SSL/TLS 双向认证(二) -- 基于mosquittto的MQTT双向认证

MQTT双向认证
  • ustccw
  • ustccw
  • 2017年08月08日 14:31
  • 553
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[11]MQTT mosquitto 双向SSL认证配置方式
举报原因:
原因补充:

(最多只允许输入30个字)