.net-core - 如何使用 MqttNET 在 azure 函数中使用 PEM 文件

标签 .net-core mqtt pem azure-function-app

我希望你能在这里帮助我。 我正在尝试制作一个 MQTT 客户端(应用程序服务环境中的 azure 函数),从 MQTT 代理(hivemq)提取数据,但在涉及证书时我有点迷失(我不是专家)。

无论如何,我从我们的合作伙伴(即 MQTT 代理)那里收到了 3 个文件(如下所示),但问题是。我应该如何在应用程序中使用这些 PEM 文件?

  • 客户端证书== mqtt-client-cert.pem
  • 客户端 key == mqtt-client-key_nopass.pem
  • CA 证书 == server.pem

这是应用程序,这是我在本地(使用 crt 证书)针对测试代理 (test.mosquitto.org) 进行测试的示例。它工作得很好,但现在我只需要做同样的事情,只需使用 3 个 PEM 文件即可。

我还怀疑我需要在 Azure 上执行某些操作(在函数应用程序或应用程序服务环境级别)才能使用这些证书?

            // Create a new MQTT client.
            var factory = new MqttFactory();
            var mqttClient = factory.CreateMqttClient();

            // Load certificate 
            X509Certificate caCertificate = new X509Certificate(@"..\mosquitto.org.crt");

            // Create TLS based parameters.
            var tlsParameters = new MqttClientOptionsBuilderTlsParameters
            {
                UseTls = true,
                Certificates = new List<X509Certificate> { caCertificate },
                SslProtocol = System.Security.Authentication.SslProtocols.Tls12
            };

            // Create TCP based options using the builder.
            var connectOptions = new MqttClientOptionsBuilder() 
                .WithTcpServer("test.mosquitto.org", 8883)
                .WithProtocolVersion(MQTTnet.Formatter.MqttProtocolVersion.V311)
                .WithTls(tlsParameters)
                .Build();

            var conResult = await mqttClient.ConnectAsync(connectOptions);
                              
            mqttClient.UseConnectedHandler(e =>
            {
                Console.Write("Connected successfully with MQTT Brokers.");
            });
            mqttClient.UseDisconnectedHandler(e =>
            {
                Console.Write("Disconnected from MQTT Brokers.");
            });

最佳答案

.crt 文件通常包含 PEM 编码的 key /证书,因此在这种情况下,文件扩展名没有任何区别。

您应该能够将 mosquitto.org.crt 替换为 server.pem

另外 2 个文件用于所谓的双向 TLS 身份验证。对于大多数 TLS 连接(例如,对网页发出 HTTPS 请求时),只有连接的一侧需要证书/私钥。这是服务器。客户端使用 CA 证书集合来验证服务是否如其所声称的那样。 (这就是您使用 mosquitto.org.crt 文件所做的事情)。

在其他情况下,我们希望对连接的两端进行身份验证(客户端想知道服务器是什么,服务器想知道客户端是谁)。为此,客户端还需要向服务器提供证书,这就是其他 2 个文件的用途。

MQTTNet 文档包含使用客户端证书设置连接的示例 here但它使用 .pfx (pfx 只是 PKCS12 容器的另一个名称,如果需要,您可以使用将 .pem 文件转换为 .pfx/.p12 文件openssl 例如 openssl pkcs12 -export -out mqtt-client.p12 -inkey mqtt-client-key_nopass.pem -in mqtt-client-cert.pem -CAfile server.pem)

List<X509Certificate> certs = new List<X509Certificate>
{
    new X509Certificate2("myCert.pfx")
};

var options = new MqttClientOptionBuilder()
    .WithTcpServer(broker, port)
    .WithTls(new MqttClientOptionsBuilderTlsParameters
    {
        UseTls = true,
        Certificates = certs
    })
    .Build();

关于.net-core - 如何使用 MqttNET 在 azure 函数中使用 PEM 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65417907/

相关文章:

c# - 如何解决 SqlNullValueException?

c# - ASP.NET 样板 .NET Core 2

c# - 单元测试传递字符串参数除 null 或空之外的任何字符串值

asp.net-core - 不支持关键字 : 'userid' error

java - Android MQTT 客户端订阅在 API 级别 26 下无法工作

c# - 将 X509 证书中的私钥/公钥导出到 PEM

c# - 如何从 pem 文件或 xml 文件中读取 RSA 公钥

perl - 使用 perl Crypt::X509 从证书中提取数据

linux - 在linux中通过MQTT.FX模拟MQTT TLS登录?

node.js - mqtt.js 自动关闭连接