我一直在尝试获得 nodemailer 的基本组合,使用 mailtrap.io 帐户工作,并删除。
这是我的 app.js:
const nodemailer = require('nodemailer');
let transport = nodemailer.createTransport({
host: "smtp.mailtrap.io",
port: 2525,
// secure: true,
auth: {
user: "myusername",
pass: "mypassword"
},
debug: true,
logger: true
});
let scrapeEmailMessage = {
//from: 'myemail@gmail.com',
to: 'myemail@gmail.com',
subject: 'Hello World',
text: 'hello world'
};
let mailTransporter = nodemailer.createTransport(transport);
mailTransporter.sendMail(scrapeEmailMessage, function(err, data) {
if(err) {
console.log(err);
} else {
console.log('Email sent successfully');
}
});
这是我得到的错误输出:
[2020-11-10 14:32:20] DEBUG Creating transport: nodemailer (6.4.15; +https://nodemailer.com/; SMTP/6.4.15[client:6.4.15])
[2020-11-10 14:32:20] DEBUG Creating transport: nodemailer (6.4.15; +https://nodemailer.com/; SMTP/6.4.15[client:6.4.15])
[2020-11-10 14:32:20] DEBUG Sending mail using SMTP/6.4.15[client:6.4.15]
[2020-11-10 14:32:20] DEBUG [YlvPyvxQxE] Resolved localhost as 127.0.0.1 [cache miss]
[2020-11-10 14:32:22] ERROR [YlvPyvxQxE] connect ECONNREFUSED 127.0.0.1:587
[2020-11-10 14:32:22] DEBUG [YlvPyvxQxE] Closing connection to the server using "destroy"
[2020-11-10 14:32:22] ERROR Send Error: connect ECONNREFUSED 127.0.0.1:587
Error: connect ECONNREFUSED 127.0.0.1:587
at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1129:14) {
errno: 'ECONNREFUSED',
code: 'ESOCKET',
syscall: 'connect',
address: '127.0.0.1',
port: 587,
command: 'CONN'
}
我尝试了很多方法来修复它,并不断收到相同的错误消息:
- 打开 Gmail 中的“不太安全的应用程序”选项并使用上面的代码尝试连接到 smtp.gmail.com。
- 在上面的代码中手动编辑端口号。
- 在上面的代码中打开和关闭安全模式。
- 在端口 587、465 以及其他几个端口上添加 Windows Defender 防火墙例外只是为了好玩,看看它们是否可以工作。
- 完全禁用 Windows Defender 防火墙。
- 在我的家庭网络上的其他计算机上运行代码。
- 检查“netstat -an”以查看是否列出了端口 587 或 465。他们不是,但是这个端口是一直打开还是只在需要时打开?这可能是问题吗?
有人对这里可能发生的事情有任何想法吗?我只是一个普通人,使用他的家庭互联网连接编写一个小程序,每天向自己发送一次电子邮件警报。我的 ISP 会阻止这个吗?
编辑-添加一些我尝试过但没有奏效的新东西:
- 传输选项“ignoreTLS:真/假”(都尝试过)
- 传输选项“requireTLS:true/false”(两者都试过)