2012-08-07 101 views
0

我正在尝试为用户添加html文件到我的Heroku应用程序的非常简单的方法。这些文件将被保存在./log中以供稍后渲染。我已经测试我的代码在本地(在开发和生产),但是当我尝试上传文件在我的Heroku托管回购,我得到的内部服务器错误500Rails 3 Heroku应用程序,FileUtils错误服务器端

控制器 upload.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 

视图 uploadfile.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" 

Heroku的日志:

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 

的Heroku:http://upload-example.herokuapp.com/

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

没有试图说服我使用回形针或carrierwave,不回答我的问题。任何帮助将大大赞赏,在此先感谢家伙!

+0

看看这是否有帮助? http://stackoverflow.com/questions/3691746/heroku-file-upload-problem – GnrlBzik 2012-08-07 14:44:12

+0

你读过这个吗? https://devcenter.heroku.com/articles/read-only-filesystem – GnrlBzik 2012-08-07 14:48:58

+0

我重读https:// devcenter。heroku.com/articles/read-only-filesystem,我想我可能误解了./log 的用法我也在https://devcenter.heroku.com/articles/s3上阅读,如果我理解正确,请使用Amazon S3不会允许我使用外部html部分。 因此,我现在在如何完成外部html部分上传损失。 – JonahAaron 2012-08-07 15:21:58

回答

0

你应该看看这篇文章在Heroku:https://devcenter.heroku.com/articles/read-only-filesystem

编辑:

如在文章写道。

您的应用程序被编译为一个快速分布在dyno流形中的slug。 slug的文件系统是只读的,这意味着你不能动态地向文件系统写入半永久存储。不支持以下几种行为:在公共目录

  • 保存上传资源到本地磁盘

    • 缓存页面(例如与attachment_fu或回形针)
    • 编写全文索引与鼬
    • 写入文件系统数据库SQLite的类似或GDBM
    • 访问一个git回购像git的维基应用程序

    有两个可写的目录:./tmp和./log(在你的应用程序根目录下)。如果您希望在请求期间临时删除文件,则可以写入文件名,如#{RAILS_ROOT}/tmp/myfile _#{Process.pid}。不能保证这个文件会在后续请求中出现(尽管它可能是),所以这不应该用于任何类型的永久存储。

  • +0

    虽然这并不能解决我的问题,但我在阅读链接(再次)后意识到Heroku从来没有打算让人们去做我正在尝试做的事情。因此,无论我需要在其他地方托管还是找到替代文件上传的方法。 – JonahAaron 2012-08-07 19:20:14

    +0

    谢谢,但我不知道除了给出解释这个资源的链接之外还有其他词组。 – GnrlBzik 2012-08-07 19:34:57

    +0

    从文章中添加片段只是为了使这个答案更相关。 – GnrlBzik 2012-08-07 19:40:09