我正在尝试通过 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(不是代码问题,而是找不到任何凭据。根据此页面,它会自动按以下顺序检查:
- 环境变量。
- 共享凭据文件。
- 如果您的应用程序在 Amazon EC2 实例上运行,则为 Amazon EC2 的 IAM 角色。
如果它在一个环境中工作而不是另一个环境,我猜您有一个 IAM 角色,该角色具有通过实例配置文件与 EC2 实例关联的必要权限。
若要显式设置凭据,请尝试以下操作:
staticCreds = credentials.NewStaticCredentials("<key-id>", "<secret>", "<session token>")
session, err = session.NewSession(&aws.Config{Credentials: staticCreds})