在我的一生中,我无法弄清楚如何在我的 iOS 项目中实现亚马逊的 sdk,而且我似乎找不到太多关于我正在尝试做的事情的文档......希望你能提供帮助!
我想非常简单地从我的 Amazon S3 帐户下载文件并将它们本地存储在 iPhone 上...我可以通过 http 地址访问图像来做到这一点,但这并不能像我一样保护图像会更喜欢。
根据我的阅读,我应该做这样的事情:
AmazonS3Client *s3Client = [[AmazonS3Client alloc] initWithAccessKey:@"mykey" withSecretKey:@"mysecretkey"];
S3GetObjectRequest *requestedObject = [[S3GetObjectRequest alloc] initWithKey:bucketPath withBucket:@"mybucket"];
NSLog(@"requestedobject:%@", requestedObject - I get the log here);
S3GetObjectResponse *getObjectResponse = [s3Client getObject:requestedObject];
NSLog(@"requestedobject2:%@", getObjectResponse - it crashes before this happens);
NSData *myData2;
myData2 = getObjectResponse.body;
[myData2 writeToFile:bucketPath atomically:YES];
我显然在 getObjectResponse、getObject 代码上做错了,但我想不出正确的语法...任何帮助将不胜感激!
这是日志: 2012-08-02 17:12:33.856 Collection Master Edition[13176:4e07] 请求对象: 2012-08-02 17:12:34.044 Collection Master Edition[13176:4e07] * 由于未捕获的异常“AmazonServiceException”而终止应用程序,原因:“(null)”
也许我还应该提到我可以使用以下代码获取存储桶列表内容
S3ListObjectsRequest *listObjectRequest = [[S3ListObjectsRequest alloc] initWithName:@"my bucket"];
S3ListObjectsResponse *listObjectResponse = [s3Client listObjects:listObjectRequest];
S3ListObjectsResult *listObjectsResults = listObjectResponse.listObjectsResult;
for (S3ObjectSummary *objectSummary in listObjectsResults.objectSummaries) {
NSLog(@"Bucket Contents:%@" ,[objectSummary key]); // This returns the contents of the bucket
}
谢谢! 扎克
最佳答案
据我所见,您可能遇到以下两个问题之一。刚开始使用 AWS 时,我遇到了类似的问题。首先确保您的存储桶名称全部为小写字母。您应该通过将错误放在 @try - @catch block 中并记录错误来检查为什么会发生这种情况,这些错误在找出您的问题时提供了非常详细的信息。
-(UIImage *)getImageFromS3{
@try{
AmazonS3Client *_s3Client = [[AmazonS3Client alloc]initWithAccessKey:ACCESS_KEY withSecretKey:SECRET_KEY];
S3GetObjectRequest *getObjectRequest = [[S3GetObjectRequest alloc]initWithKey:imageKey withBucket:pictureBucket];
S3GetObjectResponse *response = [_s3Client getObject:getObjectRequest];
if (response.error == nil)
{
if (response.body != nil)
{
UIImage *someImage = [UIImage imageWithData:reponse.body];
return someImage;
}
else{
NSLog(@"There was no value in the response body");
return nil;
}
}
else if (response.error != nil)
{
NSLog(@"There was an error in the response while getting image: %@",response.error.description);
}
}
@catch (NSException *exception) {
NSLog(@"There was an exception when connecting to s3: %@",exception.description);
}
}
关于ios - amazon s3 iphone sdk 下载图片,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11785872/
从给定URL下载文件并立即将其上传到AmazonS3的更直接的方法是什么(+将有关文件的一些信息保存到数据库中,例如名称、大小等)?现在,我既不使用Paperclip,也不使用Carrierwave。谢谢 最佳答案 简单明了:require'open-uri'require's3'amazon=S3::Service.new(access_key_id:'KEY',secret_access_key:'KEY')bucket=amazon.buckets.find('image_storage')url='http://www.ex
我正在编写一个小脚本来定位aws存储桶中的特定文件,并创建一个临时验证的url以发送给同事。(理想情况下,这将创建类似于在控制台上右键单击存储桶中的文件并复制链接地址的结果)。我研究过回形针,它似乎不符合这个标准,但我可能只是不知道它的全部功能。我尝试了以下方法:defauthenticated_url(file_name,bucket)AWS::S3::S3Object.url_for(file_name,bucket,:secure=>true,:expires=>20*60)end产生这种类型的结果:...-1.amazonaws.com/file_path/file.zip.A
这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下
当我尝试安装Ruby时遇到此错误。我试过查看this和this但无济于事➜~brewinstallrubyWarning:YouareusingOSX10.12.Wedonotprovidesupportforthispre-releaseversion.Youmayencounterbuildfailuresorotherbreakages.Pleasecreatepull-requestsinsteadoffilingissues.==>Installingdependenciesforruby:readline,libyaml,makedepend==>Installingrub
我是Rails的新手,所以请原谅简单的问题。我正在为一家公司创建一个网站。那家公司想在网站上展示它的客户。我想让客户自己管理这个。我正在为“客户”生成一个表格,我想要的三列是:公司名称、公司描述和Logo。对于名称,我使用的是name:string但不确定如何在脚本/生成脚手架终端命令中最好地创建描述列(因为我打算将其设置为文本区域)和图片。我怀疑描述(我想成为一个文本区域)应该仍然是描述:字符串,然后以实际形式进行调整。不确定如何处理图片字段。那么……说来话长:我在脚手架命令中输入什么来生成描述和图片列? 最佳答案 对于“文本”数
我正在尝试解析一个文本文件,该文件每行包含可变数量的单词和数字,如下所示:foo4.500bar3.001.33foobar如何读取由空格而不是换行符分隔的文件?有什么方法可以设置File("file.txt").foreach方法以使用空格而不是换行符作为分隔符? 最佳答案 接受的答案将slurp文件,这可能是大文本文件的问题。更好的解决方案是IO.foreach.它是惯用的,将按字符流式传输文件:File.foreach(filename,""){|string|putsstring}包含“thisisanexample”结果的
?博客主页:https://xiaoy.blog.csdn.net?本文由呆呆敲代码的小Y原创,首发于CSDN??学习专栏推荐:Unity系统学习专栏?游戏制作专栏推荐:游戏制作?Unity实战100例专栏推荐:Unity实战100例教程?欢迎点赞?收藏⭐留言?如有错误敬请指正!?未来很长,值得我们全力奔赴更美好的生活✨------------------❤️分割线❤️-------------------------
1.错误信息:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)或者:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:TLShandshaketimeout2.报错原因:docker使用的镜像网址默认为国外,下载容易超时,需要修改成国内镜像地址(首先阿里
print"Enteryourpassword:"pass=STDIN.noecho(&:gets)puts"Yourpasswordis#{pass}!"输出:Enteryourpassword:input.rb:2:in`':undefinedmethod`noecho'for#>(NoMethodError) 最佳答案 一开始require'io/console'后来的Ruby1.9.3 关于ruby-为什么不能使用类IO的实例方法noecho?,我们在StackOverflow上
我目前正在使用带有Carrierwavegem的Rails3.2将文件上传到AmazonS3。现在我需要能够处理用户提交的大于5GB的文件,同时仍然使用Carrierwavegem。Carrierwave或Fog是否有任何其他gem或分支可以处理5GB以上的文件上传到S3?编辑:我不想重写一个完整的Rails上传解决方案,所以像这样的链接没有帮助:https://gist.github.com/908875. 最佳答案 我想出了如何做到这一点,并且现在可以正常工作了。在正确的config/environment文件中,添加以下内容以