Ruby on rails文件上传

时间:2012-06-06 09:20:01

标签: ruby-on-rails-3 file-upload ruby-on-rails-3.1

今天我有一个包含文件上传的问题。

首先是一些信息:

Rubyversion:1.9.3p194(2012-04-20修订版35410)[x86_64-linux] Railsversion:Rails 3.1.1

所需代码: 我的表格

        <%= form_for @label, :html => { :multipart => true } do |f| %>
            <% if @label.errors.any? %>
                    <div id="error_explanation">
                            <h2><%= pluralize(@label.errors.count, "error") %> prohibited this label from being saved:</h2>

                            <ul>
                            <% @label.errors.full_messages.each do |msg| %>
                                    <li><%= msg %></li>
                            <% end %>
                            </ul>
                    </div>
            <% end %>
            <div class="field">
                    <%= f.label :file %><br />
                    <%= f.file_field :file %>
            </div>
            <div class="actions">
                    <%= f.submit %>
            </div>
    <% end %>

我的模特:

class Label < ActiveRecord::Base
    attr_accessor :file
    attr_reader :file

    def file=(file)
            log = Logger.new(Rails.root.join("log/label.log").to_s)
            log.info "file-Action called"
            path=file.tempfile.to_path.to_s
            filename="labellist.csv"
            dest=Rails.root.join("app/assets/csv/").join(filename).to_s
            FileUtils.cp(path, dest)
            csv=CsvLabelParser.new
            log.info "New Parser initialized!"
            csv.parse_csv(dest)
            log.info "Variables: path: #{path.inspect} <-----> dest: #{dest.inspect}"
    end
end

我的解析器

class CsvLabelParser
    require 'csv'

    def initialize
            @logger=Logger.new(Rails.root.join("log/parser.log").to_s)
    end

    def logger
            @logger
    end

    def parse_csv(path)
            counter = 0
            read_handle = File.open(path, "rb")
            content = read_handle.read
            self.logger.info "CONTENT: #{content.inspect}"
            read_handle.close

            content.each_line do |line|
                    if counter != 0
                            csv_array=line.split(";")
                            self.logger.info "CSV-Array No. #{counter}: #{csv_array.inspect}"
                            label=Label.new

                            label.labnr=csv_array[10]
                            label.name=csv_array[0]
                            label.firm1=csv_array[3]
                            label.firm2=csv_array[4]
                            label.postal=csv_array[7]
                            label.city=csv_array[8]
                            label.country=csv_array[9]
                            label.street=csv_array[5]
                            label.pob=csv_array[6]
                            label.save
                    end
                    counter += 1
            end
    end

end

控制器-登录

# Logfile created on 2012-06-06 09:49:23 +0200 by logger.rb/31641
Controller-create-method called! => variables: Params: {"utf8"=>"✓", "authenticity_token"=>"L+fpIMqFA9qe9U/LxU+atFONT8e3L5xEUum1321mRng=", "label"=>{"file"=>#<ActionDispatch::Http::UploadedFile:0x00000003df2318 @original_filename="ADRBW076-Q.csv", @content_type="text/csv", @headers="Content-Disposition: form-data; name=\"label[file]\"; filename=\"ADRBW076-Q.csv\"\r\nContent-Type: text/csv\r\n", @tempfile=#<File:/tmp/RackMultipart20120606-2741-1izzofa>>}, "commit"=>"Create Label", "action"=>"create", "controller"=>"labels"}<-----> Label: #<Label id: nil, labnr: nil, name: nil, firm1: nil, firm2: nil, postal: nil, city: nil, country: nil, street: nil, pob: nil, created_at: nil, updated_at: nil>

原来如此!如您所见,我想上传CSV文件以将其解析到我的数据库中。文件的副本应存储在名为CSV的文件夹中以供日后使用。我之前已经完成了大约5次并且它运行良好,但这次看来,模型中的文件方法没有被调用。 现在我只希望它不再工作,将来会有一些变化来捕捉错误和类似的东西;)。 我已经记录了每次调用的Controller操作。愿Logfile可以帮到你!对我来说,它看起来没问题,将它与其他日志文件进行比较。 我已经找到了一个解决方案,但一切看起来都没问题(也许我只是忘记了:或者,),所以我不能说出错了!

感谢您的帮助

1 个答案:

答案 0 :(得分:1)

我有解决方案!

我正在使用Rails 3.1.1和Ruby 1.9.3以及它的gemset。问题是新功能“attr_accessible”。通常不在Rails 3.1.1中使用,由于更新的gemset,有必要使:file-Field可访问。所以解决方案很简单,我只需添加:

attr_accessible :file, ect

到我的模型顶部,一切正常!