NodeMailer排队发送电子邮件,但电子邮件从不发送

ora*_*int 6 email smtp sendmail smtpclient nodemailer

我正在尝试从我自己的域发送电子邮件,而不使用外部SMTP服务器.我正在使用NodeMailer的SMTP连接:

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);
});
Run Code Online (Sandbox Code Playgroud)

我的服务器代码使用NodeMailer的SMTP服务器:

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);
});
Run Code Online (Sandbox Code Playgroud)

所以在我的客户端连接到我的本地SMTP服务器之后,我得到的最后一条消息是"消息排队为abcdef"并且没有任何内容发送(没有任何内容到达我的gmail收件箱或任何其他电子邮件测试服务)...

没有错误的端口被阻止,所以我必须遗漏一些东西(?).这不是如何正确使用NodeMailer的吗?我是否可以使用NodeMailer从本地域发送电子邮件?

jok*_*net 1

这里的文档有一个注释,指出:

\n\n
\n

该模块本身不会发送任何电子邮件。smtp-server\n 允许您使用 SMTP 或 LMTP\n 协议监听端口 25/24/465/587 等,并且\xe2\x80\x99s 它。您自己的应用程序负责接受消息并将其传送到目的地。

\n
\n\n

(强调我的)

\n\n

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

\n\n

稍微扩展一下消息到达 SMTP 服务器后如何发送消息。如果收件人地址是本地的,只需将邮件放入他们的邮箱即可。但如果您想“重寄”该邮件,则需要将该邮件与TO邮件交换联系。

\n\n

就像是:

\n\n
const toExchange = getMX(parsed.to);\nconst outMessage = createMessageFromParsed(parsed);\n\nconst transporter = createTransport({\n    port: 25,\n    host: toExchange,\n    name: os.hostname(),\n});\n\ntransporter.sendMail(outMessage);\n
Run Code Online (Sandbox Code Playgroud)\n