`

Ruby 多文件上传并写入数据库

阅读更多

一:建立表(用Ruby的 script/generate model attach) 顺便把模型也生成
打开 db/migrage/007_create_attaches.rb 修改成
class CreateAttaches < ActiveRecord::Migration
def self.up
    create_table :attaches, :force => true do |t|
      t.column :name,        :string # 附件名称
      t.column :url,         :string # 资源路径
      t.column :types,       :string # 附件类型,存扩展名
      t.column :size,        :integer # 附件大小
      t.column :last_update, :integer # 更新时间
    end
end

def self.down
    drop_table :attaches
end
end

执行 rake db:migrate 会自动创建表到指定的数据库

二:新建立一个UploadController 其内容如下(只是测试用,没有去美化)
class UploadController < ApplicationController

def index
    @attach_pages, @attaches = paginate :attaches, :order => 'last_update DESC', :per_page => 10
end

def add
    begin
      # 因为是多文件上传,所以这里要循环
      params[:uploadFile].each do | file |
        if file.kind_of?(StringIO) || File.exist?(file)
    # 调用自定义的模型来上传文件,传入session_id 来重命名文件,保证文件不重名
    attach = Attach.new(file, session.session_id)
    attach.save
    end
      end
    rescue
      raise
    end
    redirect_to :action => "index"
end

end

三:修改刚才自动生成的模型 Attach
class Attach < ActiveRecord::Base

def initialize(upload, session_id)
    file_upload(upload, session_id) # 执行文件上传
    super()
    self.name = @name
    self.url   = @url
    self.types = @type
    self.size = @size
    self.last_update = @last_update
end


# 文件上传
def file_upload(upload, session_id)
    time_now = Time.now
    @init_dir = "upload/#{time_now.strftime('%Y-%m-%d')}"

    begin
      FileUtils.mkpath(upload_path) unless File.directory?(upload_path)
      if upload.kind_of?(StringIO)
        upload.rewind
      end
   
      origName = upload.original_filename
      baseName = File.basename(origName, ".*")    # 取得文件名字
      extName = File.extname(origName).downcase # 取得文件扩展名
      tmpName = "_1"
      tmpExtName = "_" + time_now.to_i.to_s + extName
     
      # 重命名
      baseName = session_id.nil? ? Digest::MD5.hexdigest(baseName).to_s : session_id.to_s
      baseName = baseName.upcase
      endName = baseName + tmpExtName
     
      # 生成不重复的文件名
      while File.exist?(upload_path(endName))
        arr = endName.scan(/[a-zA-Z0-9_]+/)[0].split("_")
    endName = 2 == arr.size ? (baseName + tmpName + tmpExtName ) : (baseName + "_" + arr[1].succ.to_s + tmpExtName )
      end
     
      # 将文件写入磁盘
      File.open(upload_path(endName), "wb") { |f| f.write(upload.read) }

      @name = origName
      @url = "/#{@init_dir}/#{endName}"
      @type = (extName.delete ".")
      @size = upload.size
      @last_update = time_now.to_i

    rescue
      raise
    end

end

# 生成绝对路径
def upload_path(file = nil)
    "#{RAILS_ROOT}/public/#{@init_dir}/#{file.nil? ? '' : file}"
end
end

四:修改views/upload/index.rhtml
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>文件上传测试</title>
</head>

<body>

<!-- 用于显示已经上传的文件 -->
<table border="1">
<tr>
<% for column in Attach.content_columns %>
    <th><%= column.human_name %></th>
<% end %>
</tr>

<% for attach in @attaches %>
<tr>
<% for column in Attach.content_columns %>
    <td><%=h attach.send(column.name) %></td>
<% end %>
</tr>
<% end %>
</table>



<!-- 用[]命名是为了Ruby得到的是一个文件数组 -->
<h1>文件上传</h1>
<% form_tag({:action => :add}, {:multipart => true}) do -%>

文件名称1:<%= file_field_tag "uploadFile[]" -%> <br/><br/>
文件名称2:<%= file_field_tag "uploadFile[]" -%> <br/><br/>
文件名称3:<%= file_field_tag "uploadFile[]" -%> <br/><br/>
文件名称4:<%= file_field_tag "uploadFile[]" -%> <br/><br/>
文件名称5:<%= file_field_tag "uploadFile[]" -%> <br/><br/>

<%= submit_tag "文件上传", :disable_with => "文件上传中..." , :name => "btnSave", :id => "btnSave" %>

<% end %>
</body>
</html>

分享到:
评论
1 楼 rogerer 2010-12-23  
paginate 这个是哪里来的?

相关推荐

    ROR 文件的上传与下载

    `save`方法接收一个文件对象,读取其二进制流,并使用`ActiveRecord`的`create`方法将文件信息写入数据库。如果需要将文件存储在服务器磁盘上而不是数据库中,可以修改`save`方法以使用`File.open`方法将文件写入...

    Ruby-ActiveImporter能够加载电子表格或CVS文件的数据至任何类似ActiveRecord的ORM框架中

    2. **创建导入器**:创建一个新的Ruby文件,继承自`ActiveImporter::Base`,并指定目标模型和数据映射。 3. **定义数据映射**:映射电子表格的列到ActiveRecord模型的属性。 4. **执行导入**:在应用中调用`import`...

    mira:从CSV文件创建简单的API

    通过将datapackage.json文件上传到项目,可以为Mira提供有关CSV文件的信息。 该文件提供了您计划上传到项目的CSV文件的元数据。 即文件名,列名和类型,分隔符等。有关datapackage.json文件和表格数据包的更多信息...

    Ruby on Rails下的图像处理入门教程

    Carrierwave提供了一种优雅的方式处理文件上传,同时与MiniMagick配合良好。添加`gem 'carrierwave'`和`gem 'carrierwave-mongoid'`到Gemfile,根据数据库类型(如Mongoid、ActiveRecord等)进行相应的配置。 创建...

    Task5:导入导出文件

    至于标签"JavaScript",虽然在描述中没有直接提及JavaScript,但在Web开发中,JavaScript经常用于前端交互,包括处理文件上传和下载。如果这个任务涉及Web应用,那么JavaScript可能被用来创建用户友好的界面,实现...

    msf命令汇总

    - **write**: 写入文件。 - **run**: 执行Meterpreter的内置命令。 **file management**: - **cat**: 查看文件内容。 - **cd**: 更改目录。 - **del**: 删除文件。 - **download**: 下载文件。 - **edit**: 编辑...

    Hadoop权威指南(中文版)2015上传.rar

    文件写入剖析 一致模型 通过 distcp并行拷贝 保持 HDFS 集群的均衡 Hadoop的归档文件 使用Hadoop归档文件 不足 第4章 Hadoop I/O 数据完整性 HDFS的数据完整性 LocalFileSystem ChecksumFileSystem 压缩 codec 压缩...

    hadoop_the_definitive_guide_3nd_edition.pdf

    - **命令行接口**:介绍如何通过命令行对HDFS进行基本的操作,如文件上传、下载、删除等。 - **Java API**:提供详细的Java接口文档,用于开发基于HDFS的应用程序。 - **读取数据**:通过Hadoop URL读取文件,使用...

    csv_uploader

    总结起来,"csv_uploader"项目涉及到Rails 5框架的基本使用,包括MVC架构、数据库操作、文件上传处理、用户界面设计以及错误处理等核心概念。通过实践这个项目,开发者可以深入理解如何在Rails中实现数据导入功能,...

    isdsp-desktop:一个由学生和老师组成的文件共享平台

    后端开发方面,isdsp-desktop可能采用了服务器端的技术,如PHP、Python、Node.js或Ruby on Rails,来处理用户请求、管理数据库、实现文件上传和下载功能。数据库管理系统,如MySQL或MongoDB,用于存储和检索教师上传...

    图片

    在GitHub Pages上发布图片,通常需要将图片文件上传到仓库的"gh-pages"分支。你可以通过GitHub API或者git命令行工具来实现这个过程。Ruby的Octokit库可以方便地与GitHub API交互: ```ruby require 'octokit' ...

    roo:Roo为Open Office,Excel和Google Spreadsheets提供了一个界面

    在Web应用中,它可以用于导入用户上传的电子表格,进行数据验证或处理,然后将结果存入数据库。 6. **社区支持**:虽然原作者不再维护,但`roo` 仍在社区的积极开发下持续更新。新版本的开发应该从指定的存储库获取...

    java开源包1

    Java文件上传组件 COS FAT文件系统读写类库 fat32-lib fat32-lib 是一个用来读写 FAT 16/32 格式文件系统的纯 Java 类库(纯的)。 Eclipse的HTML格式化插件 Eclipse Tidy Eclipse HTML Tidy 是一款 Eclipse 的...

    java开源包11

    Java文件上传组件 COS FAT文件系统读写类库 fat32-lib fat32-lib 是一个用来读写 FAT 16/32 格式文件系统的纯 Java 类库(纯的)。 Eclipse的HTML格式化插件 Eclipse Tidy Eclipse HTML Tidy 是一款 Eclipse 的...

    java开源包2

    Java文件上传组件 COS FAT文件系统读写类库 fat32-lib fat32-lib 是一个用来读写 FAT 16/32 格式文件系统的纯 Java 类库(纯的)。 Eclipse的HTML格式化插件 Eclipse Tidy Eclipse HTML Tidy 是一款 Eclipse 的...

    java开源包3

    Java文件上传组件 COS FAT文件系统读写类库 fat32-lib fat32-lib 是一个用来读写 FAT 16/32 格式文件系统的纯 Java 类库(纯的)。 Eclipse的HTML格式化插件 Eclipse Tidy Eclipse HTML Tidy 是一款 Eclipse 的...

    java开源包6

    Java文件上传组件 COS FAT文件系统读写类库 fat32-lib fat32-lib 是一个用来读写 FAT 16/32 格式文件系统的纯 Java 类库(纯的)。 Eclipse的HTML格式化插件 Eclipse Tidy Eclipse HTML Tidy 是一款 Eclipse 的...

    java开源包5

    Java文件上传组件 COS FAT文件系统读写类库 fat32-lib fat32-lib 是一个用来读写 FAT 16/32 格式文件系统的纯 Java 类库(纯的)。 Eclipse的HTML格式化插件 Eclipse Tidy Eclipse HTML Tidy 是一款 Eclipse 的...

    java开源包10

    Java文件上传组件 COS FAT文件系统读写类库 fat32-lib fat32-lib 是一个用来读写 FAT 16/32 格式文件系统的纯 Java 类库(纯的)。 Eclipse的HTML格式化插件 Eclipse Tidy Eclipse HTML Tidy 是一款 Eclipse 的...

Global site tag (gtag.js) - Google Analytics