好吧,这让我疯了.
我正在尝试创建一个简单的AWS S3客户端,它允许与S3进行基本交互,但似乎我做错了什么并且无法弄清楚它是什么.它可能很明显,但我没有看到它.
我的密钥是正确的并且已经过测试 – 没有尾随空格等.
问题似乎与签名有关,它不断得到’我们计算的请求签名与您提供的签名不匹配.从Amazon的REST API检查您的密钥和签名方法错误.我创建了各种类别,添加了base64,HMAC SHA1生成功能,我还查看了各种在线示例,但到目前为止还没有成功.
不使用亚马逊提供的库的原因是因为它针对的是Cocoa Touch,我不想破解它以使其适用于Cocoa.
您可以在此处获取所有文件/代码的副本:https://www.dropbox.com/s/8ts9q71dz3uopxp/S3Lite.zip
然而,我关注亚马逊关于身份验证的文档,而且简单地说,一切都正确完成.
这是我如何生成签名:
- -(NSString *)signRequest:(NSURLRequest *)request {
- NSMutableString *sig = [[NSMutableString alloc] init];
- // Request Method
- [sig appendFormat:@"%@\n",[request HTTPMethod]];
- // Content MD5
- [sig appendFormat:@"%@\n",[[request HTTPBody] MD5String]];
- // Content Type
- [sig appendFormat:@"%@\n",[request valueForHTTPHeaderField:@"Content-Type"]];
- // Date
- [sig appendFormat:@"%@\n",[request valueForHTTPHeaderField:@"Date"]];
- // Canonicalized Headers
- [sig appendFormat:@"%@\n",@""]; // Empty for now
- // Canonicalized Resource
- [sig appendFormat:@"%@",[NSString stringWithFormat:@"/%@%@",_bucket,request.URL.path]];
- NSString *encodedString = [[[sig dataUsingEncoding:NSUTF8StringEncoding] hmacSHA1SignatureWithKey:_secretKey] base64String];
- return [[NSString alloc] initWithFormat:@"AWS %@:%@",_accessKey,encodedString];
- }
以下是您如何使用它来尝试执行简单的PUT请求.
- #import "S3Lite.h"
- S3Lite *aws = [[S3Lite alloc] initWithAccessKey:@"<access key>"
- secretKey:@"<secret key>"
- bucketName:@"<bucket name>"
- region:kAmazonS3EUWest1Region
- useSSL:NO];
- NSData *file = [[NSData alloc] initWithContentsOfFile:@"<path to a file>"];
- [aws putObjectWithData:file inPath:@"aRandomFile.png" withContentType:nil];
任何正确方向的帮助将不胜感激.
小号
解决方法
即使您无法直接使用AWS SDK for iOS,它也是开源的,您可能会从检查请求签名代码中获得一些想法:
https://github.com/aws/aws-sdk-ios/blob/master/AWSCore/Authentication/AWSSignature.m