扩展白名单似乎不起作用



我对载波宝石有问题。Extension_whitelist似乎不起作用。

  def extension_whitelist
    %w(csv)
  end

我不知道为什么它不起作用。我导入什么类型的文件并不重要,它永远不会引发错误。这是我的其余代码:

class AttachmentUploader < CarrierWave::Uploader::Base
  storage :file
  def store_dir
    "uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}"
  end
  def extension_whitelist
    %w(csv)
  end
end

控制器(基本上清除带有格式化和响应的脚手架)

class PackagesController < ApplicationController
  before_action :set_package, only: [:show, :edit, :update, :destroy]
  # GET /packages
  # GET /packages.json
  def index
    @packages = Package.all
  end
  # GET /packages/1
  # GET /packages/1.json
  def show
  end
  # GET /packages/new
  def new
    @package = Package.new
  end
  # GET /packages/1/edit
  def edit
  end
  # POST /packages
  # POST /packages.json
  def create
    @package = Package.new(package_params)
    respond_to do |format|
      if @package.save
        format.html { redirect_to @package, notice: 'Package was successfully created.' }
        format.json { render :show, status: :created, location: @package }
      else
        format.html { render :new }
        format.json { render json: @package.errors, status: :unprocessable_entity }
      end
    end
  end
  # PATCH/PUT /packages/1
  # PATCH/PUT /packages/1.json
  def update
    respond_to do |format|
      if @package.update(package_params)
        format.html { redirect_to @package, notice: 'Package was successfully updated.' }
        format.json { render :show, status: :ok, location: @package }
      else
        format.html { render :edit }
        format.json { render json: @package.errors, status: :unprocessable_entity }
      end
    end
  end
  # DELETE /packages/1
  # DELETE /packages/1.json
  def destroy
    @package.destroy
    respond_to do |format|
      format.html { redirect_to packages_url, notice: 'Package was successfully destroyed.' }
      format.json { head :no_content }
    end
  end
  private
    # Use callbacks to share common setup or constraints between actions.
    def set_package
      @package = Package.find(params[:id])
    end
    # Never trust parameters from the scary internet, only allow the white list through.
    def package_params
      params.require(:package).permit(:name, :description, :category_id)
    end
end

在寻找答案时,我也看到了:

  def content_type_whitelist
    /csv//
  end

但它也不起作用。任何想法可能是什么问题?另外,还有其他简单的方法可以实现吗?

@EDIT问题已解决:我很久以前就报告了此错误,最近已修复。

该方法

需要调用extension_white_list而不是extension_whitelist

在主分支上 这最近已重命名为 extension_whitelist(请参阅提交),但此更改尚未成为公开发布的 gem。

你可以在模型中使用它

validates_attachment_content_type :attachment, :content_type => 'text/plain'

还可以找出要列入白名单的内容,这里是文件类型的完整列表 http://www.sitepoint.com/web-foundations/mime-types-complete-list/

查看您的评论,File_validators宝石就是您正在寻找的:https://github.com/musaffa/file_validators

您将能够在上传之前验证文件(大小和内容类型)。

最新更新