Node.js Ошибка конфигурации HTTPS - нет общих алгоритмов шифрования - PullRequest
0 голосов
/ 06 мая 2018

Я видел другие подобные вопросы, но они не решают мою проблему. Я сгенерировал свой самоподписанный сертификат TLS (openSSL), но, похоже, не работает на моем NodeJS сервере.

Инструкция по генерации SSL

openssl req -newkey rsa:2048 -keyout key.pem -x509 -days 365 -out certificate.pem

openssl x509 -text -noout -in certificate.pem

openssl pkcs12 -inkey key.pem -in certificate.pem -export -out certificate.p12

openssl pkcs12 -in certificate.p12 -noout -info  // verify certificate

Итак, в конце у меня есть .p12, также известный как PFX сертификат типа. Ниже мой Node.js код:

    // ------- Start HTTPS configuration ----------------

const options = {

    pfs: fs.readFileSync('./server/security-certificate/certificate.p12'),     
    passphrase: 'secrete2'
};
https.createServer(options, app).listen(8443);


    // -------- End HTTPS configuration -----------------

    // Also listen for HTTP 
var port = 8000;
app.listen(port, function(){
    console.log('running at localhost: '+port);
});

Вот вывод, когда я запускаю команду curl, HTTP-запрос обслуживается правильно, только HTTPS имеет проблему:

Output when tested on same machine

Более того, если я сделаю это:

export CURL_CA_BUNDLE=/var/www/html/node_app/server/security-certificate/cert.p12

Тогда я получаю следующую ошибку: curl: (77) Problem with the SSL CA cert (path? access rights?)



Если я пытаюсь получить доступ в браузере с HTTPS и портом, браузер говорит, что не может загрузить страницу.

Ссылочные ссылки, по которым я следовал: Node.js HTTPS:

https://nodejs.org/dist/latest-v8.x/docs/api/https.html#https_https_createserver_options_requestlistener

Я использую AWS RedHat Linux

1 Ответ

0 голосов
/ 10 мая 2018

Пока не известно решение указанной выше проблемы, связанной с моим .p12 комплектным сертификатом (используется в моей Node.js конфигурации).

Однако я заметил, что когда я изменил код и попытался использовать сертификат .pem, он работал правильно с командой curl -k <MY-URL>.

const options = {
    cert: fs.readFileSync('./server/security-certificate/cert.pem'),    
    key: fs.readFileSync('./server/security-certificate/key.pem'),      

    //pfs: fs.readFileSync('./server/security-certificate/cert.p12'),   // didn't work

    passphrase: 'secrete'
};

https.createServer(options, app).listen(8443);

Если кто-нибудь знает лучшее решение / ответ, пожалуйста, напишите это. Пока я не уверен, почему сертификат .p12 не работает. Должен ли я переименовать его в .pfx (в чем отличие и эффект)?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...