将JSON文件作为未经身份验证的用户AWS / S3 / Cognito下载

时间:2017-12-15 00:04:30

标签: swift amazon-s3 aws-sdk

我正在尝试在我的AWS账户上下载我的S3中的JSON文件。我创建了一个Unauthenticated cognito池,并将其从示例代码中复制到我的app delegate中:

    let credentialsProvider = AWSCognitoCredentialsProvider(regionType:.USWest2,
                                                            identityPoolId:"us-west-2:59a31a8f-ee6a-45fe-adaa-fa3eff871c80")

    let configuration = AWSServiceConfiguration(region:.USWest2, credentialsProvider:credentialsProvider)

    AWSServiceManager.default().defaultServiceConfiguration = configuration

在我的视图控制器中,我有以下代码:

    let transferManager = AWSS3TransferManager.default()
    let downloadingFileURL = URL(fileURLWithPath: NSTemporaryDirectory()).appendingPathComponent("db_storage/costdb_latest.json ")

    if let downloadRequest = AWSS3TransferManagerDownloadRequest(){
        downloadRequest.bucket = "coast-s3-bucket"
        downloadRequest.key = "db_storage/costdb_latest.json "
        downloadRequest.downloadingFileURL = downloadingFileURL


        transferManager.download(downloadRequest).continueWith(executor: AWSExecutor.default(), block: { (task: AWSTask<AnyObject>) -> Any? in
            if( task.error != nil){
                print(task.error!.localizedDescription)
                return nil
            }

            print(task.result!)

            if let data = NSData(contentsOf: downloadingFileURL){
                DispatchQueue.main.async(execute: { () -> Void in
                    print(data)
                })
            }
            return nil
        })
    }

桶和池都在同一个区域。 USWest2(俄勒冈州)。我的存储桶是公开的,我已将AmazonS3FullAccess和AmazonS3ReadOnlyAccess添加到我的策略中。我收到了这个错误:

The operation couldn’t be completed. (com.amazonaws.AWSS3ErrorDomain error 4.)

1 个答案:

答案 0 :(得分:0)

它不是身份验证/授权错误(我认为)。从它的外观来看,配置存在一些问题(区域,端点等)。通常,这些错误包含对错误的完整描述。尝试记录完整的错误消息。

另请参阅S3 TransferManager的this示例应用程序。使用你的S3&amp; Cognito细节。如果这样可行,则存在一些代码问题,您可以通过比较这两者来找到它们。如果这不起作用,那么这可能是服务问题。