NodeMailer对传出电子邮件进行排队,但电子邮件从不发送

时间:2018-11-19 14:32:07

标签: email smtp sendmail smtpclient nodemailer

我正在尝试从我自己的域发送电子邮件,而不使用外部SMTP服务器。我正在使用NodeMailer's SMTP connection

let options = {
    secure: true,
    port: consts.portOut,//465
    host: consts.host, //mydomain.com
    transactionLog: true,
    debug: true,
    requireTLS: true,
    authMethod: 'PLAIN',
};

let connection = new SMTPConnection(options);

connection.connect(function() {
    let auth = {
        user: 'abc',
        pass: 'def'
    };

    connection.login(auth, function(err) {
        if (err) {
            console.log("Authentication failed!", err);
        }
        console.log("Authentication to SMTP server successful.");

        let envelope = {
            from: 'fee@mydomain.com',
            to: 'myemail@gmail.com'
        };

        let message = 'message hello world';

        connection.send(envelope, message, function(err, info) {
            if (err) {
                console.log("err:::", err);
            } else {
                console.log('info?', info);
                //connection.quit();
            }
        });

        connection.quit();

    });

});

connection.on("error", function(err) {
    console.log(err);
});

我的服务器代码使用NodeMailer's SMTP Server

const options = {
    secure: true,
    size: 25000000, //25MB
    authMethods: ['PLAIN'],
    key: hskey,
    cert: hscert,
    ca: [hschain],
    onAuth(auth, session, callback) {
        if(auth.username !== 'abc' || auth.password !== 'def') {
            return callback(new Error('Invalid username or password'));
        }
        callback(null, {user: 123}); // where 123 is the user id or similar property
    },
    onConnect(session, callback) {
        console.log("the address is:", session.remoteAddress)
        if (session.remoteAddress === consts.ip) {
            return callback(); // Accept the address
        } else {
            return callback(new Error('Only connections from %s allowed', consts.ip));
        }

    },
    onData(stream, session, callback) {
        simpleParser(stream, (err, parsed) => {
            if(err) {
                console.error(err);
            } else {
                console.log(parsed);
            }

        });
        stream.on('end', function () {
            let err;
            if(stream.sizeExceeded){
                err = new Error('Message exceeds fixed maximum message size');
                err.responseCode = 552;
                return callback(err);
            }
            callback(null, 'Message queued as abcdef');
        });
    }

};

const emailServer = new SMTPServer(options);

emailServer.listen(consts.portOut, function () {
    processSMTPConnection(consts, hskey);
});

emailServer.on("error", function (err) {
    console.error("Error %s", err.message);
});

因此,在我的客户端连接到本地SMTP服务器之后,我收到的最后一条消息是“消息以abcdef形式排队”并且什么都没有发送(什么也没有到达我的gmail收件箱或任何其他电子邮件测试服务中)...

没有阻止不正确的端口,因此我必须缺少某些内容(?)。 这不是正确使用NodeMailer的方法吗? 我应该可以使用NodeMailer从本地域发送电子邮件吗?

1 个答案:

答案 0 :(得分:1)

文档here的注释中指出:

  

此模块本身不会发送任何电子邮件。 SMTP服务器   允许您使用SMTP或LMTP监听端口25/24/465/587等   协议就是这样。 您自己的应用负责   接受并将邮件传递到目的地。

(重点是我的)

您的服务器似乎接受了电子邮件(这就是为什么它显示邮件已排队的原因),但没有传递到目的地。

详细介绍邮件到达SMTP服务器后如何发送。如果TO地址是本地地址,只需将邮件放在他们的邮箱中即可。但是,如果您要“转寄”邮件,则需要与TO邮件交换联系并提供邮件。

类似的东西:

const toExchange = getMX(parsed.to);
const outMessage = createMessageFromParsed(parsed);

const transporter = createTransport({
    port: 25,
    host: toExchange,
    name: os.hostname(),
});

transporter.sendMail(outMessage);