首先,我知道SO中有很多与此类似的问题。在过去的一周里,我读了大部分(如果不是全部)。但我仍然无法让这项工作为我工作。
我正在开发一个 Ruby on Rails 应用程序,允许用户将 mp3 文件上传到 Amazon S3。上传本身工作正常,但进度条将大大改善网站的用户体验。
我正在使用 aws-sdk gem,这是亚马逊的官方宝石。我在上传过程中到处查看了其文档中的回调,但我找不到任何东西。
文件一次一个地直接上传到 S3,因此不需要将其加载到内存中。也无需上传多个文件。
我想我可能需要使用 JQuery 来完成这项工作,我对此很满意。
我发现这看起来很有希望:https://github.com/blueimp/jQuery-File-Upload https://github.com/blueimp/jQuery-File-Upload我什至尝试按照这里的例子:https://github.com/ncri/s3_uploader_example https://github.com/ncri/s3_uploader_example
但我就是无法让它为我工作。
aws-sdk 的文档还简要描述了使用块进行流式上传:
obj.write do |buffer, bytes|
# writing fewer than the requested number of bytes to the buffer
# will cause write to stop yielding to the block
end
但这几乎没有帮助。如何“写入缓冲区”?我尝试了一些直观的选项,但总是会导致超时。我该如何根据缓冲来更新浏览器?
有没有更好或更简单的解决方案?
先感谢您。
对于这个问题的任何帮助,我将不胜感激。
将块传递给 #write 时生成的“缓冲区”对象是 StringIO 的实例。您可以使用#write 或#
file = File.open('/path/to/file', 'r')
obj = s3.buckets['my-bucket'].objects['object-key']
obj.write(:content_length => file.size) do |buffer, bytes|
buffer.write(file.read(bytes))
# you could do some interesting things here to track progress
end
file.close
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)