TypeError:在node.js中使用aws-sdk发送电子邮件时,密钥必须是缓冲区

时间:2018-02-19 13:16:13

标签: node.js config aws-sdk amazon-ses node-config

我正在尝试设置一个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有什么特别的东西可以打破代码吗?

3 个答案:

答案 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.0config.util.toObject(someValue)以允许您为给定的配置值返回一个普通的旧JavaScript对象。它记录在我们的utils wiki page

如果你有node-config的旧版本并且不想升级,你也可以在node-config返回的配置结构上执行此操作:

var plainOldValue = JSON.parse(JSON.stringify(configValue)

这具有删除node-config添加的方法的效果,正是新的.toObject()方法在内部执行的操作。