从 AWS SES 发送电子邮件时出现凭证错误



我正在尝试通过 Golang 中的 Amazon SES 发送电子邮件。以前,它使用以下代码在开发服务器(没有 SSL(上工作:

sess, err := session.NewSession(&aws.Config{
Region:aws.String(AwsRegion)},
)
/* Create an SES client in the session */
svc := ses.New(sess)
/* Assemble the email */
input := &ses.SendEmailInput{
Destination: &ses.Destination{
CcAddresses: []*string{
},
ToAddresses: []*string{
aws.String(request.EmailTo),
},
},
Message: &ses.Message{
Body: &ses.Body{
Html: &ses.Content{
Charset: aws.String(CharSet),
Data:    aws.String(body),
},
},
Subject: &ses.Content{
Charset: aws.String(CharSet),
Data:    aws.String(subject),
},
},
Source: aws.String("test<test@example.com>"),
}
/* Attempt to send the email */
result, err := svc.SendEmail(input)

最近我开始在生产服务器(使用 SSL(上工作,相同的代码开始给我以下错误:

NoCredentialProviders: no valid providers in chain. Deprecated.
For verbose messaging see aws.Config.CredentialsChainVerboseErrors

我尝试像这样向代码添加凭据:

creds := credentials.NewCredentials(&ec2rolecreds.EC2RoleProvider{})
/* updated session block with credentials in aws config */
sess, err := session.NewSession(&aws.Config{
Region: aws.String(AwsRegion),
Credentials: creds})

但是这段代码不起作用(甚至没有编译(,并给了我以下错误:

/main.go:63:42: undefined: ec2rolecreds

但是,我已经在代码中包含凭据包。

我不知道如何向此代码添加凭据,以便它也在生产服务器上工作。任何形式的帮助将不胜感激。

第一个错误(NoCredentialProviders(不是代码问题,而是找不到任何凭据。根据此页面,它会自动按以下顺序检查:

  1. 环境变量。
  2. 共享凭据文件。
  3. 如果您的应用程序在 Amazon EC2 实例上运行,则为 Amazon EC2 的 IAM 角色。

如果它在一个环境中工作而不是另一个环境,我猜您有一个 IAM 角色,该角色具有通过实例配置文件与 EC2 实例关联的必要权限。

若要显式设置凭据,请尝试以下操作:

staticCreds = credentials.NewStaticCredentials("<key-id>", "<secret>", "<session token>")
session, err = session.NewSession(&aws.Config{Credentials: staticCreds})

相关内容

  • 没有找到相关文章

最新更新