javascript - MQTT SSL 对等端未返回证书

标签 javascript ssl mqtt tls1.2 mosquitto

我通过链接生成了 CA、服务器和客户端证书,https://mosquitto.org/man/mosquitto-tls-7.html

还在 mosquitto 服务器配置文件中添加了以下行。

listener 8883
cafile certs/ca.crt
certfile certs/server.crt
keyfile certs/server.key
require_certificate true

然后我写了下面的 javascript 客户端来连接到服务器。

    var mqtt = require('mqtt');
    var fs = require('fs');
    var KEY = fs.readFileSync('G:/Projects/test/client.key');
    var CERT = fs.readFileSync('G:/Projects/test/client.crt');
    var TRUSTED_CA_LIST = [fs.readFileSync('C:/Program Files (x86)/mosquitto - Copy/certs/ca.crt')];

    var PORT = 8883;
    var HOST = 'localhost';

    var options = {
      port: PORT,
      host: HOST,
      protocol: 'mqtts',
      keyPath: KEY,
      certPath: CERT,
      passphrase: 'testnode',
      rejectUnauthorized : false,
      //The CA list will be used to determine if server is authorized
      ca: TRUSTED_CA_LIST,
      secureProtocol: 'TLSv1_method',
      protocolId: 'MQIsdp',
      protocolVersion: 3
    };

    var client = mqtt.connect(options);

    client.subscribe('messages');
    client.publish('messages', 'Current time is: ' + new Date());
    client.on('message', function(topic, message) {
      console.log(message);
    });

    client.on('connect', function(){
        console.log('Connected');
    });

但是当我运行这段代码时,服务器会抛出以下错误。

1464240743: New connection from 127.0.0.1 on port 8883.
1464240743: OpenSSL Error: error:140890C7:SSL routines:ssl3_get_client_certifica
te:peer did not return a certificate
1464240743: Socket error on client <unknown>, disconnecting.

最佳答案

根据 this .

keyPath更改为key,将certPath更改为cert

关于javascript - MQTT SSL 对等端未返回证书,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37452458/

相关文章:

facebook - 我可以为安全的 Canvas URL 使用免费的自签名 SSL 证书吗?

Javascript - 如何从 MQTT 将变量值插入数据库

javascript - 如何从ajax响应中获取请求的url?

javascript - OpenShift + Diet.js

javascript - 对直接或嵌套属性进行排序

ssl - 在 OpenStack 服务器中发布到 Mosquitto

activemq - 最大 MQTT 连接数

javascript - 事件监听器何时附加到 Node.js 中?

java - 是否可以让 Java 忽略 "trust store"并接受它获得的任何 SSL 证书?

spring - 如何将自定义 SSL 证书注入(inject) springbok bootBuildImage