我没有使用回形针、carrierwave 或任何其他 gem 来与亚马逊网络服务 s3 进行交互。事实上,我没有使用任何模型,只是直接与 S3 对象交互。
有人可以提供一些关于如何从 AWS S3 直接下载对象(文件)的代码吗
到目前为止,这是我的代码:
看法:
<h2>Download Files</h2>
<%@root_files.each do |file| %>
<% next if @obj %>
<td>Filename: <b><%= file %></b></td>
<td><%= link_to "Download", download_url_for(file) %></td>
<% end %>
对应控制器:
def xxx
bucket = AWS::S3.new.buckets[ ENV["BUCKET"]]
@root_files = bucket.as_tree.children.select(&:leaf?).collect(&:key)
end
download_url_for 方法:
def download_url_for(file_key)
s3 = AWS::S3.new
bucket = s3.buckets[ ENV["BUCKET"]]
object = bucket.objects[file_key]
File.open('xxxxx', 'wb') do |file|
object.read do |chunk|
file.write(chunk)
end
end
end
我需要能够将下载的文件保存在桌面上任何可浏览的非预定位置。我非常感谢关于如何修改 download_url_for 方法来实现这一点的看法。
====================================== 我刚刚尝试使用
<td><%= link_to "Download",object.value.url_for(:read).to_s %></td>
但是在下载时,我只得到一个包含 xml 内容的 zip 文件,而不是原始文件(在我的例子中是 word 文档)---关于如何修改它以获得实际文件类型和内容的任何想法?谢谢
=======================这是我上传文件的代码
查看代码:
<%= form_tag({:action => 'create_file'}, multipart: true) do %>
<%= file_field_tag 'uploaded_file' %><br />
<%= submit_tag 'Upload' %> <br />
<% end %>
控制器动作- create_file 动作
def create_file
s3 = AWS::S3.new
bucket = s3.buckets[ENV["BUCKET"]]
key = params[:uploaded_file].original_filename
object = bucket.objects[key]
object.write(params[:uploaded_file].read)
end
如果这是@Frederick Cheung 提到的问题,有人可以建议我如何在上传时检查 MIME 类型或保留文件名吗?谢谢