我正在使用JPEGCAM来允许用户使用他们的网络摄像头拍摄个人资料照片。这样就会上传一个临时文件:
def ajax_photo_upload
File.open(upload_path, 'w:ASCII-8BIT') do |f|
f.write request.raw_post
end
# @user.photo = File.open(upload_path)
@user.assign_attributes(
:photo => File.open(upload_path),
:orig_filename => "#{current_user.full_name}.jpg"
)
if @user.save
respond_to do |format|
.....
private
def upload_path # is used in upload and create
file_name = session[:session_id].to_s + '.jpg'
File.join(::Rails.root.to_s, 'public', 'temp', file_name)
end
安全删除此临时文件的最佳方法是什么?感谢
答案 0 :(得分:106)
当您知道自己已完成该文件时:
File.delete(path_to_file) if File.exist?(path_to_file)
另一件事:确保您始终关闭已打开的文件,操作系统只能处理一定数量的打开文件/文件描述符,当您通过该限制时,您可能会遇到奇怪的错误...因此,当您想要在Ruby中打开文件时,始终使用块形式:
File.open(path) do |f|
# ...
end
并且Ruby将自动为您关闭文件。如果阻止表单不可用,则必须自己关闭文件:
f = File.open(path)
# ...
f.close
因此,请务必关闭传递给@user.assign_attributes(...)
的文件...
答案 1 :(得分:27)
如果您确定已完成此操作,为什么不使用FileUtils.rm
或FileUtils.rm_f
?
FileUtils.rm_f(upload_path)
http://www.ruby-doc.org/stdlib-1.9.3/libdoc/fileutils/rdoc/FileUtils.html#method-c-rm_f
你也可以在Rails中忽略它,并且有一个cron唤醒并从temp目录中删除与这些临时文件匹配的一天以前的文件。如果文件无法重新处理,那么这会带来一些错误的好处 - 你不会立即执行它 - 并且Rails的请求/响应循环上没有完成文件操作,然后它会更快地响应。 / p>