ruby-on-rails - que - ruby on rails tutorial
Método no definido attr_accessible (3)
Asegúrese de instalar la gema ''protected_attributes'', de que esta gema está presente en su gemfile y ejecute el bundle install
terminal. Luego reinicia tu servidor.
Soy un poco nuevo en los rieles y estoy tratando de crear un inicio de sesión de usuario. Revisé el tutorial que se encuentra here . Al final, tuve que agregar "attr_accessible" para la asignación masiva. Sin embargo, cuando lo hice, recibí el siguiente error:
undefined method `attr_accessible'' for #<Class:0x007ff70f276010>
Vi en esta post que necesitaba <ActiveRecord :: Base. Pero tengo eso incluido. Aquí está el código para mi modelo de usuario:
class User < ActiveRecord::Base
attr_accessor :password
EMAIL_REGEX = //A[A-Z0-9._%+-]+@[A-Z0-9.-]+/.[A-Z]{2,4}/z/i
validates :username, :presence => true, :uniqueness => true, :length => { :in => 3..20 }
validates :email, :presence => true, :uniqueness => true, :format => EMAIL_REGEX
validates :password, :confirmation => true #password_confirmation attr
validates_length_of :password, :in => 6..20, :on => :create
before_save :encrypt_password
after_save :clear_password
attr_accessible :username, :email, :password, :password_confirmation
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
Cualquier otra idea sobre lo que podría estar causando este problema sería muy apreciada, ¡gracias!
Edición: On Rails 4.1. Parece que ya no se aplica. Gracias fotanus
No se permite ninguna asignación masiva para Rails 4.1
En lugar de tener attr_accessible :username, :email, :password, :password_confirmation
en su modelo, use parámetros fuertes . Harás esto en tu UsersController:
def user_params
params.require(:user).permit(:username, :email, :password, :password_confirmation)
end
luego llame al método user_params en las acciones de su controlador.
No se permite ninguna asignación masiva para Rails 4.1
Tendrás que probar algo como esto.
class Person
has_many :pets
accepts_nested_attributes_for :pets
end
class PeopleController < ActionController::Base
def create
Person.create(person_params)
end
...
private
def person_params
# It''s mandatory to specify the nested attributes that should be whitelisted.
# If you use `permit` with just the key that points to the nested attributes hash,
# it will return an empty hash.
params.require(:person).permit(:name, :age, pets_attributes: [ :name, :category ])
end
end
Referir