1. ホーム
  2. ruby-on-rails

[解決済み] 新規ユーザー作成時に ActiveModel::ForbiddenAttributesError が発生する。

2022-01-29 14:43:53

質問

このモデルをRubyで作成したのですが、このモデルでは ActiveModel::ForbiddenAttributesError

class User < ActiveRecord::Base
  attr_accessor :password
  validates :username, :presence => true, :uniqueness => true, :length => {:in => 3..20}
  VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-.]+\.[a-z]+\z/i
  validates :email, presence: true, :uniqueness => true, format: { with: VALID_EMAIL_REGEX }

  validates :password, :confirmation => true
  validates_length_of :password, :in => 6..20, :on => :create

  before_save :encrypt_password
  after_save :clear_password

  def encrypt_password
    if password.present?
      self.salt = BCrypt::Engine.generate_salt
      self.encrypted_password= BCrypt::Engine.hash_secret(password, salt)
    end
  end

  def clear_password
    self.password = nil
  end
end

このアクションを実行すると

  def create
    @user = User.new(params[:user])
    if @user.save
      flash[:notice] = "You Signed up successfully"
      flash[:color]= "valid"
    else
      flash[:notice] = "Form is invalid"
      flash[:color]= "invalid"
    end
    render "new"
  end

について ruby 1.9.3p194 (2012-04-20 revision 35410) [x86_64-linux] .

このエラーをなくす方法、または適切なユーザー登録フォームを確立する方法を教えていただけませんか?

解決方法を教えてください。

Rails4を使っているのでしょう。その場合、必要なパラメータは必須とマークされている必要があります。

このようにするといいかもしれません。

class UsersController < ApplicationController

  def create
    @user = User.new(user_params)
    # ...
  end

  private

  def user_params
    params.require(:user).permit(:username, :email, :password, :salt, :encrypted_password)
  end
end