2011-10-23 14 views
9

He estado jugando con has_secure_password y me encontré con un problema. Mi prueba para la acción crear en mi UsersController no fue trabajando pasando. Así que comencé a jugar en la consola y me di cuenta de que la contraseña no se estaba convirtiendo a un has y guardada en el campo password_digest.Rails 3.1.1 has_secure_password digest no puede estar en blanco

Cuando intento crear un usuario desde la consola sucede lo siguiente.

irb(main):031:0> u = User.new(:email => "[email protected]", :password => "test", :password_confirmation => "test") 
=> #<User id: nil, email: "[email protected]", password_digest: nil, created_at: nil, updated_at: nil> 
irb(main):032:0> u.save 
=> false 
irb(main):033:0> u.errors 
=> #<ActiveModel::Errors:0x00000100cde500 @base=#<User id: nil, email: "[email protected]", password_digest: nil, created_at: nil, updated_at: nil>, @messages={:password_digest=>["can't be blank"]}> 

No estoy seguro de qué estoy haciendo mal. Parece que el atributo password_digest nunca se asigna. Si creo un objeto de usuario sin atributos y le asigno cada atributo individualmente, obtengo el mismo error.

Aquí es mi modelo

class User < ActiveRecord::Base 
    has_secure_password 
    attr_accessible :email, :password, :password_confirmation 
end 

Gracias por la ayuda de antemano.

Alex Shenoy

Respuesta

0

hice un ejemplo simple y funcionó como se esperaba. Quizás tengas algo en tu configuración que esté jugando con esto. Mi prueba sencilla:

$ rails new test 
$ cd test 
$ rails g model user name:string password_digest:string 
$ rake db:migrate 
$ vim app/model/user.rb 

añadir

has_secure_password 
attr_accessible :name, :password, :password_confirmation 

parada de salida

$ rails c 

Loading development environment (Rails 3.1.1) 
ruby-1.9.2-p290 :001 > u = User.new(:name => "[email protected]", :password => "test", :password_confirmation => "test") 
=> #<User id: nil, name: "[email protected]", password_digest: "$2a$10$08xY7p.8hq1.95ZQsx63ku05YfvVqSQ/CLiqUW5dtGhZ...", created_at: nil, updated_at: nil> 
ruby-1.9.2-p290 :002 > u.save 
Binary data inserted for `string` type on column `password_digest` 
    SQL (51.4ms) INSERT INTO "users" ("created_at", "name", "password_digest", "updated_at") VALUES (?, ?, ?, ?) [["created_at", Sun, 23 Oct 2011 13:38:49 UTC +00:00], ["name", "[email protected]"], ["password_digest", "$2a$10$08xY7p.8hq1.95ZQsx63ku05YfvVqSQ/CLiqUW5dtGhZSP9S7FtUy"], ["updated_at", Sun, 23 Oct 2011 13:38:49 UTC +00:00]] 
=> true 
10

que tenían el mismo síntoma, un mensaje que el password_digest no puede estar en blanco. El problema que tuve fue que me había propuesto esto en el user.rb:

attr_accessor :password 

Esto impidió que la contraseña method = de ser llamado (ver secure_password.rb)

# Encrypts the password into the password_digest attribute. 
    def password=(unencrypted_password) 
    @password = unencrypted_password 
    unless unencrypted_password.blank? 
     self.password_digest = BCrypt::Password.create(unencrypted_password) 
    end 
    end 

y por lo tanto el valor era nunca se configuró para el password_digest.

Para mí, la solución era eliminar la línea attr_accessor.

2

Tuve un problema muy similar. El mío salvaría al usuario, pero password_digest siempre fue nil. Para mí era porque tenía el siguiente orden código en mi modelo:

attr_accessible :name, :password, :password_confirmation 
has_secure_password 

lo cambié a:

has_secure_password 
attr_accessible :name, :password, :password_confirmation 

Ahora funciona perfectamente.

Cuestiones relacionadas