无法批量分配受保护的属性:password_confrimation

时间:2012-05-20 07:31:35

标签: ruby-on-rails ruby ruby-on-rails-3

我不知道为什么我收到关于质量分配受保护的以下错误。虽然我的配置设置为config.active_record.whitelist_attributes = false

Follwoing是模型和控制器的代码

有什么想法吗?

      ActiveModel::MassAssignmentSecurity::Error in UsersController#create 
Can't mass-assign protected attributes: password_confrimation
Rails.root: C:/Users/huzaifa.gain/My Documents/Aptana Studio 3 Workspace/blog

Application Trace | Framework Trace | Full Trace
app/controllers/users_controller.rb:7:in `new'
app/controllers/users_controller.rb:7:in `create'


Request

Parameters: 
{"utf8"=>"?",
 "authenticity_token"=>"CIPrmS9ZZlgUELOMkAT6Htw1eLPMxmXRh7Ur7doeYcY=",
 "user"=>{"email"=>"huzi",
 "password"=>"[FILTERED]",
 "password_confrimation"=>"[FILTERED]"},
 "commit"=>"Create User"}


class UsersController < ApplicationController
  def new 
    @user = User.new
  end

  def create
    @user = User.new(params[:user])
    if @user.save
       redirect_to_ articles_path, :notice => 'User successfully added.'
     else 
       render :action =>'new'
    end
  end

  def edit
    @user = User.find(parms[:id]) 
  end

  def update
    @user = User.find(parms[:id])
    if @user.update_attributes(params[:user])
      redirect_to articles_path, :notice => 'Updated user information successfully'
    else 
      render :action => 'edit'
    end
  end
end


require 'digest'
class User < ActiveRecord::Base

  attr_accessor  :email, :password , :password_confirmation
  attr_accessible :email, :password , :password_confirmation
  validates :email, :uniqueness => true, 
                                    :length => {:within => 5..50},
                                    :presence => true

  validates :password, :confirmation => true, :length => { :within => 4..20 }, :presence => true, :if => :password_required?

  has_one :profile

  has_many :articles, :order => 'published_at DESC, title ASC',
                      :dependent => :nullify
  has_many :replies, :through => :articles, :source => :comments

  before_save :encrypt_new_password

  def self.authenticate(email, password)
    user = find_by_email(email)
        return user if user && user.authenticated?(password)
  end

  def authenticated?(password)
    self.hashed_password == encrypt(password)
  end


  def encrypt_new_password
    return if password.blank?
      self.hashed_password  = encrypt(password)                                                                                                                                                                                                                                                                                                                                                                                                                                                              
  end

  def password_required?
    hashed_password.blank? || password.present?
  end

 def encrypt(string)
   Digest::SHA2.hexdigest(string)
 end 


end

2 个答案:

答案 0 :(得分:5)

我认为这是因为拼写错误。您的模型有attr_accessible :email, :password , :password_confirmation,但看起来您的表单拼写为password_confrimation。

答案 1 :(得分:0)

更改您的表单:

:password_confrimation

为:

:password_confirmation

这是一个错字。