【发布时间】:2015-04-15 20:50:35
【问题描述】:
在 iOS 8 中使用 AWSSDK V2,完成示例代码库和设置 cognito 可以正确访问我的 S3Bucket。下面的例子在这里
https://github.com/awslabs/aws-sdk-ios-samples/tree/master/S3BackgroundTransfer-Sample/Objective-C
当我尝试上传时出现此错误
Error: Error Domain=com.amazonaws.AWSS3PresignedURLErrorDomain Code=1
"accessKey in credentialProvider can not be nil" UserInfo=0x7d905610
{NSLocalizedDescription=accessKey in credentialProvider can not be nil}
我确保 cognito poold id 使用的角色可以根据我为其创建的策略访问我的 s3 存储桶。可能是什么问题?
在 sebastians commnent 之后,我返回并验证我使用的是未经身份验证的用户,其角色可以访问我的 s3bucket,然后查看了他关于 cognito 异步及其初始化的最后评论。我在这里用这个方法做这个
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
AWSCognitoCredentialsProvider *credentialsProvider = [AWSCognitoCredentialsProvider credentialsWithRegionType:CognitoRegionType
identityPoolId:CognitoIdentityPoolId];
AWSServiceConfiguration *configuration = [AWSServiceConfiguration configurationWithRegion:DefaultServiceRegionType
credentialsProvider:credentialsProvider];
[AWSServiceManager defaultServiceManager].defaultServiceConfiguration = configuration;
// Override point for customization after application launch.
return YES;
}
现在当断线时
[AWSServiceManager defaultServiceManager].defaultServiceConfiguration = configuration;
并在调试器中检查 credentialsProvider 的属性,它确实有很多 nil 属性!!
credentialsProvider AWSCognitoCredentialsProvider * 0x7886a0d0 0x7886a0d0
NSObject NSObject
_useEnhancedFlow BOOL YES '\x01'
_identityId NSString * nil 0x00000000
_accessKey NSString * nil 0x00000000
_secretKey NSString * nil 0x00000000
_sessionKey NSString * nil 0x00000000
_expiration NSDate * nil 0x00000000
我确实创建了实体池并将 ID 嵌入到我的代码中,我应该在这里寻找什么?
【问题讨论】:
标签: ios amazon-web-services amazon-s3