【发布时间】:2019-10-01 22:52:10
【问题描述】:
下面是我从 s3 获取对象的代码。此代码在我设置了 aws 配置文件和配置文件的机器上本地运行。我的印象是,如果我给我的 ecs 任务一个可以访问 s3 的角色,那么这仍然可以工作,而无需我将访问密钥和密钥传递给我的代码中的 s3Client。
S3 获取代码
public async Task GetFilesFromS3Async(IEnumerable<FileDownloadViewModel> attachments)
{
foreach (var attachment in attachments)
{
var request = new GetObjectRequest()
{
BucketName = "bucketname",
Key = $"{attachment.SubBucket}/{attachment.ObjectId}/{attachment.FileName}"
};
using(var s3response = await _client.GetObjectAsync(request))
{
using (var memoryStream = new MemoryStream())
{
await s3response.ResponseStream.CopyToAsync(memoryStream);
memoryStream.Position = 0;
attachment.FileBytes = memoryStream.ToArray();
}
}
}
}
s3 客户端初始化
private readonly IAmazonS3 _client;
public S3Service(IAmazonS3 client)
{
_client = client;
}
startup.cs 代码
services.AddAWSService<IAmazonS3>();
我的任务和 ec2 实例上的角色都有允许对 s3 进行写入/读取操作的策略。
编辑
我的 ec2 实例和运行容器的服务的策略:(基本上所有 s3 的 get 和 put 操作)
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "VisualEditor0",
"Effect": "Allow",
"Action": [
"s3:PutAnalyticsConfiguration",
"s3:GetObjectVersionTagging",
"s3:CreateBucket",
"s3:ReplicateObject",
"s3:GetObjectAcl",
"s3:GetBucketObjectLockConfiguration",
"s3:DeleteBucketWebsite",
"s3:PutLifecycleConfiguration",
"s3:GetObjectVersionAcl",
"s3:DeleteObject",
"s3:GetBucketPolicyStatus",
"s3:GetObjectRetention",
"s3:GetBucketWebsite",
"s3:PutReplicationConfiguration",
"s3:PutObjectLegalHold",
"s3:GetObjectLegalHold",
"s3:GetBucketNotification",
"s3:PutBucketCORS",
"s3:GetReplicationConfiguration",
"s3:ListMultipartUploadParts",
"s3:PutObject",
"s3:GetObject",
"s3:PutBucketNotification",
"s3:PutBucketLogging",
"s3:PutBucketObjectLockConfiguration",
"s3:GetObjectVersionForReplication",
"s3:GetLifecycleConfiguration",
"s3:ListBucketByTags",
"s3:GetInventoryConfiguration",
"s3:GetBucketTagging",
"s3:PutAccelerateConfiguration",
"s3:DeleteObjectVersion",
"s3:GetBucketLogging",
"s3:ListBucketVersions",
"s3:RestoreObject",
"s3:GetBucketPolicy",
"s3:PutEncryptionConfiguration",
"s3:GetEncryptionConfiguration",
"s3:GetObjectVersionTorrent",
"s3:AbortMultipartUpload",
"s3:GetBucketRequestPayment",
"s3:GetObjectTagging",
"s3:GetMetricsConfiguration",
"s3:DeleteBucket",
"s3:PutBucketVersioning",
"s3:GetBucketPublicAccessBlock",
"s3:ListBucketMultipartUploads",
"s3:PutMetricsConfiguration",
"s3:GetBucketVersioning",
"s3:GetBucketAcl",
"s3:PutInventoryConfiguration",
"s3:GetObjectTorrent",
"s3:PutBucketWebsite",
"s3:PutBucketRequestPayment",
"s3:PutObjectRetention",
"s3:GetBucketCORS",
"s3:GetBucketLocation",
"s3:ReplicateDelete",
"s3:GetObjectVersion"
],
"Resource": [
"arn:aws:s3:::bucket/*",
"arn:aws:s3:::bucket"
]
}
]
}
在我的前端应用程序的控制台中,我也收到了一个 cors 错误,但在我的应用程序的其他任何地方都没有出现 cors 问题。
【问题讨论】:
标签: amazon-web-services asp.net-core amazon-s3