ruby-on-rails – 使用Ruby aws-sdk跟踪上传文件到S3的进度
发布时间:2020-12-16 19:16:21 所属栏目:百科 来源:网络整理
导读:首先,我知道在SO中有很多类似于这个的问题.在过去的一周里,我读过大多数(如果不是全部的话).但我仍然不能为我做这项工作. 我正在开发一个Ruby on Rails应用程序,允许用户将mp3文件上传到Amazon S3.上传本身效果很好,但进度条可以极大地改善网站上的用户体验.
首先,我知道在SO中有很多类似于这个的问题.在过去的一周里,我读过大多数(如果不是全部的话).但我仍然不能为我做这项工作.
我正在开发一个Ruby on Rails应用程序,允许用户将mp3文件上传到Amazon S3.上传本身效果很好,但进度条可以极大地改善网站上的用户体验. 我正在使用aws-sdk gem,这是来自亚马逊的官方宝石.在上传过程中,我在其文档中随处可见回调,但我找不到任何内容. 文件一次一个地上传到S3,因此不需要将其加载到内存中.也不需要多文件上传. 我想我可能需要使用JQuery来完成这项工作,我很好. 但我无法让它对我有用. 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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |