Nodemailer - сервер MS Exchaneg - ошибка не удается проверить первый сертификат - PullRequest
2 голосов
/ 14 марта 2019

Я пытаюсь отправить электронную почту с NodeJS, используя почтовый сервер MS Exchange вне офиса. с кодом ниже. И получить ошибку

Наш администратор сказал, что сертификаты не нужны.

Error: -

$ node test2.js
Error :  { Error: unable to verify the first certificate
    at TLSSocket.onConnectSecure (_tls_wrap.js:1048:34)
    at TLSSocket.emit (events.js:182:13)
    at TLSSocket._finishInit (_tls_wrap.js:628:8) code: 'ESOCKET', command: 'CONN' }

Код NodeJS: -

"use strict";
const nodemailer = require("nodemailer");

async function main() {
    try {
        // create reusable transporter object using the default SMTP transport
        let transporter = nodemailer.createTransport({
            host: 'host',
            port: 25,
            secure : false, // true for 465, false for other ports
            auth: {
                user: 'user',
                pass: 'password'
            }
        });

        // setup email data
        let mailOptions = {
            from: 'me@email.com',
            to: 'me@email.com',
            subject: 'Hey you, awesome!',
            html: '<b>This is bold text</b>',
            text: 'This is text version!'
        };

        // send mail with defined transport object
        let info = await transporter.sendMail(mailOptions)
        console.log("Message sent: %s", JSON.stringify(info));

    } catch (error) {
        console.log('Error : ', error);
    }
}

main(); // For testing

1 Ответ

5 голосов
/ 15 марта 2019

Приведенное ниже изменение кода решило проблему. Добавил это в createTransport ()

 tls: {rejectUnauthorized: false}

Код: -

   // create reusable transporter object using the default SMTP transport
    let transporter = nodemailer.createTransport({
        host: 'host',
        port: 25,
        secure : false, // true for 465, false for other ports
        auth: {
            user: 'user',
            pass: 'password'
        },
        tls: {
            // do not fail on invalid certs
            rejectUnauthorized: false
        },
    });
...