为什么我在使用nodemailer时遇到此错误? SSL23_GET_SERVER_HELLO:未知

时间:2016-06-08 19:45:01

标签: javascript node.js server-side nodemailer serverside-javascript

我正在使用nodemailer构建通知应用程序,我不断收到此错误:

[Error: 140735155404800:error:140770FC:SSL routines:SSL23_GET_SERVER_HELLO:unknown protocol:../deps/openssl/openssl/ssl/s23_clnt.c:794:]

我正在使用我的工作的smtp服务器。我是一个smtp菜鸟所以任何帮助将不胜感激。 我没有任何传输方法发送电子邮件,但在几封电子邮件后,邮件对象会报告我的电子邮件处于“待处理状态”:

{"accepted":[],"rejected":[],"pending":[{"domain":"xxxxx.com","exchange":"xxxx.xxxx.com",...

当我尝试直接连接到主机时,会出现上述消息。

这是我的代码:

 //import nodemailer
var nodemailer = require('nodemailer');

// create reusable transporter object using SMTP
var transporter = nodemailer.createTransport({
     host: 'chelsmtp01.karmalab.net',
    port: '25',
    secure:true,
});



//email details
var mailOptions = {
    from: 'XXX', // sender address
    to: 'XXX', // list of receivers
    subject: stitle, // Subject line
    text: message, // plaintext body
    html: message 
};

// send mail with defined transport object
transporter.sendMail(mailOptions, function(error, info){
    if(error)
        return console.log(error);

    console.log('Message sent: ' + JSON.stringify(info));

    //transporter.close();
});

我已经尝试将安全设置为false,然后即使我将requireTLS设置为true,就像其他论坛提到的那样,我得到了无效的问候错误:

[Error: Invalid greeting from server:
554 chelmtp02.karmalab.net: 554 chelmtp02.karmalab.net]
code: 'EPROTOCOL',
response: '554 chelmtp02.karmalab.net',
responseCode: 554 }

编辑:SMPT服务器不需要用户/密码

编辑:我可以在家庭网络上没有定义传输的情况下发送电子邮件。我也设法让我的Gmail也可以工作。可能是证书或网络问题

1 个答案:

答案 0 :(得分:3)

如果连接到端口25,请在配置选项中使用secure:false。使用true表示您要启动TLS连接,但端口25以纯文本格式启动并稍后升级