2013-07-26 48 views
12

我在我的視圖具有此這是一個多選複選框強參數不接受陣列

模型

class User < ActiveRecord::Base 
    has_many :user_roles, :dependent => :destroy 
    accepts_nested_attributes_for :user_roles, :allow_destroy => true 
    has_many :roles, :through => :user_roles 
end 

視圖

<%= check_box_tag 'user[role_ids][]', role.id, user.blank? ? nil : user.roles.include?(role) ,id: dom_id(role)%> 

強因爲這是參數寫爲

def user 
    params.require(:user).permit(:first_name,{:role_ids => []}) 
    end 

但在創建它說

Processing by Admin::UsersController#create as HTML 
    Parameters: {"utf8"=>"✓", "authenticity_token"=>"+y8iWya5KIILqS0embEUEZuClycXq0O9Q4pA+MnbM0g=", "user"=>{"first_name"=>"", "last_name"=>"", "email"=>"[email protected]", "language"=>"en", "access_level_id"=>"1", "role_ids"=>["", "1", "", "5", "", "", ""], "password"=>"[FILTERED]", "password_confirmation"=>"[FILTERED]"}, "commit"=>"Create user"} 

Unpermitted parameters: role_ids 
Unpermitted parameters: role_ids 
Unpermitted parameters: role_ids 
Unpermitted parameters: role_ids 

任何線索爲什麼不接受這是從形式來role_ids的陣列?

回答

7

回答我,我得到了它不是直接的工作,但是從Strong Parameters issues discussion以下方法幫助我在一個正常的參數轉換爲白名單之一。

def user_params 
    params.require(:user).permit(:first_name).tap do |whitelisted| 
    whitelisted[:role_ids] = params[:user][:role_ids] 
    end 
end 
8

這應該工作

params.require(:user).permit(:first_name, :role_ids => []) 
+1

以及我試過這種方式太..它沒有工作.. – AnkitG

+0

粘貼創建方法請 – Benj

+0

創建GIST [這裏] (https://gist.github.com/ankit8898/6088035)。請看看 – AnkitG

21

查看導軌Strong Parameters documentation regarding nested attributes

的正確格式爲:

params.permit(:name, {:roles => []}, ...) 

AnkitG's solution爲我工作在軌道4使用 Role Model寶石爲我的用戶模型。我的用戶控制器的實現_params的結束看起來像:

def user_params 
    # Bug with permit for nested arrays... @see https://stackoverflow.com/a/17880288/2631472 
    params.require(:user).permit(:first_name, :last_name, :middle_name).tap do |whitelisted| 
    whitelisted[:roles] = params[:user][:roles] 
    end 
end 

+0

爲我工作。謝謝! –