我正试图在iOS上执行AWS上传。我正在遍历一个AWSS3TransferManagerUploadRequest
对象数组,并将大量大小不同的图像(1000+)上传到S3 bucket中。使用:
AWSS3TransferManager *transferManager = [AWSS3TransferManager defaultS3TransferManager];
[[transferManager upload:request] continueWithExecutor:[BFExecutor mainThreadExecutor]
withBlock:^id(BFTask *task) {
当我到达大约第700张图像时,上传过程开始变得非常缓慢,然后我开始在随后的每一次图像上传中收到这些错误:
2015-03-27 11:07:30.238 crafted[4979:1414229] Error: Error Domain=com.amazonaws.AWSGeneralErrorDomain Code=3 "The operation couldn’t be completed. (com.amazonaws.AWSGeneralErrorDomain error 3.)" UserInfo=0x1709b5b60 {SignatureProvided=f8c21dd55c323378b05c660a5f27255a2aecbd6eee1f2ca0c5fb0460136dde30, RequestId=DB37767F9C1AFD7E, StringToSign=AWS4-HMAC-SHA256-PAYLOAD
20150327T160658Z
20150327/us-west-2/s3/aws4_request
1e63d8ac434ee08f333a4f59c52fc3565e5b451cca9c7f1a946e209fb72f24c5
e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855
11b7db18ee4cbdedc46907daa5e99688b2be72da3a943ac0354a9405b7c59f19, Code=SignatureDoesNotMatch, HostId=0V4bjdhjCG/wt/NAlsgr1K7DV6QkUdYOlwjFRfmBI/swFesufXVi19PTgacwOBt1, StringToSignBytes=41 57 53 34 2d 48 4d 41 43 2d 53 48 41 32 35 36 2d 50 41 59 4c 4f 41 44 0a 32 30 31 35 30 33 32 37 54 31 36 30 36 35 38 5a 0a 32 30 31 35 30 33 32 37 2f 75 73 2d 77 65 73 74 2d 32 2f 73 33 2f 61 77 73 34 5f 72 65 71 75 65 73 74 0a 31 65 36 33 64 38 61 63 34 33 34 65 65 30 38 66 33 33 33 61 34 66 35 39 63 35 32 66 63 33 35 36 35 65 35 62 34 35 31 63 63 61 39 63 37 66 31 61 39 34 36 65 32 30 39 66 62 37 32 66 32 34 63 35 0a 65 33 62 30 63 34 34 32 39 38 66 63 31 63 31 34 39 61 66 62 66 34 63 38 39 39 36 66 62 39 32 34 32 37 61 65 34 31 65 34 36 34 39 62 39 33 34 63 61 34 39 35 39 39 31 62 37 38 35 32 62 38 35 35 0a 31 31 62 37 64 62 31 38 65 65 34 63 62 64 65 64 63 34 36 39 30 37 64 61 61 35 65 39 39 36 38 38 62 32 62 65 37 32 64 61 33 61 39 34 33 61 63 30 33 35 34 61 39 34 30 35 62 37 63 35 39 66 31 39,
AWSAccessKeyId=ASIAJCSIGUTUKG2HSYCA,
Message=The request signature we calculated does not match the signature you provided. Check your key and signing method.}
编辑2:每个Yosuke请求的代码(我只是构建了一个请求对象数组,然后循环遍历数组并上传每个请求):
- (void)performS3UploadWithRequest:(NSMutableArray *)requests
{
for (AWSS3TransferManagerUploadRequest *request in requests) {
AWSS3TransferManager *transferManager = [AWSS3TransferManager defaultS3TransferManager];
__weak typeof(self) weakSelf = self;
[[transferManager upload:request] continueWithExecutor:[BFExecutor mainThreadExecutor]
withBlock:^id(BFTask *task) {
if (task.error) {
if ([task.error.domain isEqualToString:AWSS3TransferManagerErrorDomain]) {
switch (task.error.code) {
case AWSS3TransferManagerErrorCancelled:
case AWSS3TransferManagerErrorPaused:
break;
default:
NSLog(@"Error: %@", task.error);
break;
}
} else {
// Unknown error.
NSLog(@"Error: %@", task.error);
}
}
if (task.result) {
AWSS3TransferManagerUploadOutput *uploadOutput = task.result;
// The file uploaded successfully.
NSLog(@"%@", uploadOutput);
[weakSelf countUploadProgress];
}
return nil;
}];
}
}
- (AWSS3TransferManagerUploadRequest *)createUploadRequestWithDestinationBucket:(NSString *)destBucket Key:(NSString *)key Body:(NSURL *)body
{
AWSS3TransferManagerUploadRequest *uploadRequest = [AWSS3TransferManagerUploadRequest new];
uploadRequest.bucket = destBucket;
uploadRequest.key = key;
uploadRequest.body = body;
uploadRequest.contentType = @"binary/octet-stream";
uploadRequest.uploadProgress = ^(int64_t bytesSent, int64_t totalBytesSent, int64_t totalBytesExpectedToSend) {
dispatch_async(dispatch_get_main_queue(), ^{
if (totalBytesExpectedToSend > 0) {
NSLog(@"%f", (float)((double) totalBytesSent / totalBytesExpectedToSend));
}
});
};
return uploadRequest;
}
多亏了Yosuke,我找到了一个顺序运行for循环的解决方案。它是有点慢,但没有问题,仍然相当快,即使与1000+照片上传。
- (void)performS3UploadWithRequest:(NSMutableArray *)requests
{
AWSS3TransferManager *transferManager = [AWSS3TransferManager defaultS3TransferManager];
BFTask *task = [BFTask taskWithResult:nil];
__weak typeof(self) weakSelf = self;
for (AWSS3TransferManagerUploadRequest *request in requests) {
task = [task continueWithSuccessBlock:^id(BFTask *task) {
return [[transferManager upload:request] continueWithExecutor:[BFExecutor mainThreadExecutor]
withBlock:^id(BFTask *task) {
if (task.error) {
if ([task.error.domain isEqualToString:AWSS3TransferManagerErrorDomain]) {
switch (task.error.code) {
case AWSS3TransferManagerErrorCancelled:
case AWSS3TransferManagerErrorPaused:
break;
default:
NSLog(@"Error: %@", task.error);
break;
}
} else {
// Unknown error.
NSLog(@"Error: %@", task.error);
}
}
if (task.result) {
AWSS3TransferManagerUploadOutput *uploadOutput = task.result;
[weakSelf countUploadProgress];
// The file uploaded successfully.
NSLog(@"%@", uploadOutput);
}
return nil;
}];
}];
[task continueWithSuccessBlock:^id(BFTask *task) {
return nil;
}];
}
}
从过去的3天,我被困在同一个问题的签名。我不明白如何走出这一步。 我正在尝试获取一个预签名的网址: 我使用这个预先签名的url将图像文件上传到s3存储桶中,方法是: 并且该文件已成功上传到 s3 存储桶,我可以在 aws s3 存储桶控制台中看到。 问题是,如果我尝试从终端使用curl放置任何其他图像文件,或者尝试在浏览器中打开url,我得到的预签名url会给我带来签名不匹配错误。 如果我做错了,
我试图从我的bucket中获取一个对象,但总是出现“签名不匹配”错误。我从AWS示例代码中获得了签名生成函数,因此我确信这是可行的。我还测试了上传功能,它可以正常工作。我只是在使用get object函数时遇到了问题。我花了大量的时间来验证这篇文章中的所有场景/答案,但什么都没用。所以我在这里寻求你的帮助。 我在标题中遗漏了什么吗?以下是创建的示例规范请求: 编辑1: 我尝试使用编译AWS示例代码
我试图上传图片到s3与预先签署的url从aws SDK生成。 对于上面的返回url,当我试图访问它时,它给出了一个错误 null CORS配置 更新的解决方案
我试图生成签名的URL来上传和下载我的S3 bucket中的对象,但它失败了,“SignatureDoesNotMatch”如下所示。 我明白这是这里描述的问题的症状 而且,是的,我的桶存在。我怎么能用这个水落石出呢?
我正试图上传一张使用AWS S3 SDK的图片。现在,这以前是有效的,但由于某种原因,它停止了工作,我开始得到这个错误: 现在,当我点击链接时,它会给我一个'NoSuchKey'错误: 我真的不明白这一点,因为我的键实际上只是一个字符串。我也试图上传一些东西,所以显然关键不会存在-我正在努力上传它! 另一个教程来自一个博客,我没有它的链接,但我上面的代码与文档中的这个教程相同。我所做的只是把它移到
我有不同的对象来生成保存在S3中的文件。每个对象调用以下函数来保存文件。 我只有以下几个问题。对象要么总是保存文件,要么永远无法保存文件。 错误是 我们计算的请求签名与您提供的签名不匹配。检查您的AWS秘密访问密钥和签名方法。有关详细信息,请参阅REST身份验证和SOAP身份验证。(服务:S3,状态代码:403,请求ID:79b6c0a2-0d74-1f30-a4bf-246e9631ccd8,扩