我正在尝试设置一个nodemailer
的电子邮件系统,该系统与其使用的传输类型无关。
以下是我尝试发送电子邮件的方式:
const config = require('config')
const mailerConfig = config.get('mailer')
const transporter = nodemailer.createTransport(mailerConfig.transport)
transporter.sendMail({
from: mailerConfig.from,
to: toEmail,
subject,
text: textBody,
html: htmlBody,
})
以下是我的config
文件的样子:
const AWS = require('aws-sdk')
module.exports = {
mailer: {
from: 'test_sender@domain.com',
transport: {
SES: new AWS.SES({
accessKeyId: 'secret-key',
secretAccessKey: 'access-key',
region: 'region',
}),
},
}
}
然后,每当我尝试发送电子邮件时,都会收到以下错误:
error: TypeError: Key must be a buffer
at new Hmac (crypto.js:117:16)
at Object.Hmac (crypto.js:115:12)
at Object.hmac (/Users/sebi/Work/node_modules/aws-sdk/lib/util.js:401:30)
at Object.getSigningKey (/Users/sebi/Work/node_modules/aws-sdk/lib/signers/v4_credentials.js:59:8)
at V4.signature (/Users/sebi/Work/node_modules/aws-sdk/lib/signers/v4.js:97:36)
at V4.authorization (/Users/sebi/Work/node_modules/aws-sdk/lib/signers/v4.js:92:36)
at V4.addAuthorization (/Users/sebi/Work/node_modules/aws-sdk/lib/signers/v4.js:34:12)
at /Users/sebi/Work/node_modules/aws-sdk/lib/event_listeners.js:215:18
at finish (/Users/sebi/Work/node_modules/aws-sdk/lib/config.js:320:7)
at /Users/sebi/Work/node_modules/aws-sdk/lib/config.js:338:9
at /Users/sebi/Work/node_modules/aws-sdk/lib/credentials.js:123:23
at Credentials.refresh (/Users/sebi/Work/node_modules/aws-sdk/lib/credentials.js:194:5)
at Credentials.get (/Users/sebi/Work/node_modules/aws-sdk/lib/credentials.js:121:12)
at getAsyncCredentials (/Users/sebi/Work/node_modules/aws-sdk/lib/config.js:332:24)
at Config.getCredentials (/Users/sebi/Work/node_modules/aws-sdk/lib/config.js:352:9)
at Request.SIGN (/Users/sebi/Work/node_modules/aws-sdk/lib/event_listeners.js:192:22)
请注意,当我在我发送电子邮件的同一个地方实例化AWS.SES()
时,代码运行正常。 config
有什么特别的东西可以打破代码吗?
答案 0 :(得分:2)
配置有什么特别的东西可以破解代码吗?
完全。 config
包深度合并所有配置。所以它遍历你的配置,并打破从AWS.SES()
返回的对象。您可以尝试将密钥置于配置中,并仅在使用时将其应用于ses
:
const AWS = require('aws-sdk')
module.exports = {
mailer: {
from: 'test_sender@domain.com',
transport: {
SES: {
accessKeyId: 'secret-key',
secretAccessKey: 'access-key',
region: 'region',
},
},
}
}
并使用它:
const config = require('config')
const mailerConfig = config.get('mailer')
const transporter = nodemailer.createTransport({
SES: new AWS.SES(mailerConfig.transport.SES)
})
transporter.sendMail({
from: mailerConfig.from,
to: toEmail,
subject,
text: textBody,
html: htmlBody,
})
作为替代方案,您可以直接使用配置文件:
const config = require('./config') // depends on your files structure
答案 1 :(得分:1)
在我的情况下,accessKey和secretAccessKey是未定义的。
答案 2 :(得分:0)
我是node-config
的维护者之一。听起来这可能是node-config
在您只想要恢复普通数据时为配置对象添加了一些方法的问题。
Since v1.27.0,config.util.toObject(someValue)
以允许您为给定的配置值返回一个普通的旧JavaScript对象。它记录在我们的utils wiki page
如果你有node-config
的旧版本并且不想升级,你也可以在node-config
返回的配置结构上执行此操作:
var plainOldValue = JSON.parse(JSON.stringify(configValue)
这具有删除node-config
添加的方法的效果,正是新的.toObject()
方法在内部执行的操作。