Rails 3 Heroku app, FileUtils error server side



我正在尝试为用户编写一种非常简单的方法,将html文件添加到我的Heroku应用程序中。这些文件将保存在 ./log 中以供以后渲染。我已经在本地测试了我的代码(在开发和生产中),但是当我尝试在我的 Heroku 托管存储库上上传文件时,我收到内部服务器错误 500。

控制器上传.rb:

class UploadController < ApplicationController
  def index
     render :file => 'upload/uploadfile.haml'
  end
  def uploadFile
    file_param = params[:upload][:datafile]
    post = DataFile.save(file_param)
    render :text => "File has been uploaded successfully"
  end
end

型号 data_file.rb:

class DataFile < ActiveRecord::Base
  def self.save(upload)
    # Changed Default Destination: [__RAILS_DIR__/log]
    name = "./log/" + upload.original_filename
    # can haz data directory?
    require 'FileUtils'
    FileUtils.mkdir_p(File.dirname(name))

    File.open(name, "wb") { |f| f.write(upload.read) }
  end
end

查看上传文件.haml:

%h1 File Upload
= form_for :upload,:url=>{:action => 'uploadFile'},:html => { :multipart => true } do |f|
  %p
    %label{:for => "upload_file"} Select File
    :
    #{f.file_field 'datafile'}
  = f.submit "Upload"

英雄日志:

2012-08-07T14:13:20+00:00 app[web.1]: Started POST "/uploadFile" for 69.29.117.99 at 2012-08-07 14:13:20 +0000
2012-08-07T14:13:20+00:00 app[web.1]: Processing by UploadController#uploadFile as HTML
2012-08-07T14:13:20+00:00 app[web.1]: Parameters: {"utf8"=>"✓", "authenticity_token"=>"1dAXkMulNR0d8S/l6QC8JnpSDtNBaHoyKJezgnheR10=", "upload"=>{"datafile"=>#>}, "commit"=>"Upload"}
2012-08-07T14:13:20+00:00 app[web.1]: Completed 500 Internal Server Error in 3ms
2012-08-07T14:13:20+00:00 app[web.1]: 
2012-08-07T14:13:20+00:00 app[web.1]: LoadError (no such file to load -- FileUtils):
2012-08-07T14:13:20+00:00 app[web.1]: app/models/data_file.rb:7:in save'
2012-08-07T14:13:20+00:00 app[web.1]: app/controllers/upload_controller.rb:8:inuploadFile'
2012-08-07T14:13:20+00:00 app[web.1]: 
2012-08-07T14:13:20+00:00 app[web.1]: 
2012-08-07T14:13:20+00:00 app[web.1]: cache: [POST /uploadFile] invalidate, pass

希罗库: http://upload-example.herokuapp.com/

GitHub:https://github.com/halterj1/upload

请不要试图说服我使用回形针或载波,这并不能回答我的问题。任何帮助将胜感激,提前感谢伙计们!

你应该阅读这篇关于heroku的文章:https://devcenter.heroku.com/articles/read-only-filesystem

编辑:

如文章所述。

您的应用程序被编译成一个 slug,以便在测功机歧管中快速分发。slug 的文件系统是只读的,这意味着您无法动态写入文件系统以进行半永久存储。不支持以下类型的行为:

  • 在公共目录中缓存页面
  • 将上传的资产保存到本地磁盘(例如,使用attachment_fu或回形针)
  • 使用 Ferret 编写全文索引
  • 写入文件系统数据库,如 SQLite 或 GDBM
  • 访问像 git-wiki 这样的应用程序的 git 存储库

有两个可写的目录:./tmp 和 ./log(在您的应用程序根目录下)。如果您希望在请求期间暂时删除文件,则可以写入文件名,例如 #{RAILS_ROOT}/tmp/myfile_#{Process.pid}。不能保证此文件将在后续请求中存在(尽管可能是),因此不应将其用于任何类型的永久存储。

最新更新