#ruby-on-rails #ruby #railstutorial.org
#ruby-on-rails #ruby #railstutorial.org
Вопрос:
Это надирало мне задницу все утро.
Прямо сейчас я только начинаю главу 7.2.4 превосходного руководства Майкла Хартла по Ruby on Rails 3, и я сталкиваюсь с некоторыми проблемами. Раздел начинается с быстрой проверки has_password?
метода в изолированной среде консоли Rails. Вот что я ввел в:
ruby-1.9.2-p180 :001 > User
=> User(id: integer, name: string, email: string, created_at: datetime, updated
updated_at: datetime, encrypted_password: string, salt: string)
ruby-1.9.2-p180 :002 > User.create(:name => "John Pavlick", :email => "jmpavlick
@gmail.com", :password => "foobar", :password_confirmation => "foobar")
=> #<User id: nil, name: "John Pavlick", email: "jmpavlick@gmail.com", created_
at: nil, updated_at: nil, encrypted_password: nil, salt: nil>
ruby-1.9.2-p180 :003 > user = User.find_by_email("jmpavlick@gmail.com"
ruby-1.9.2-p180 :004?> )
=> #<User id: 1, name: "John Pavlick", email: "jmpavlick@gmail.com", created_at
: "2011-04-15 15:11:46", updated_at: "2011-04-15 15:11:46", encrypted_password:
nil, salt: nil>
ruby-1.9.2-p180 :005 > user.has_password?("foobar")
=> false
Это должно возвращаться true
.
Вот моя user.rb
модель:
class User < ActiveRecord::Base
attr_accessor :password
attr_accessible :name, :email, :password, :password_confirmation
email_regex = /^[w -.] @[a-zd-.] .[a-z] $/i
validates :name, :presence => true,
:length => { :maximum => 50 }
validates :email, :presence => true,
:format => { :with => email_regex },
:uniqueness => { :case_sensitive => false }
# Automatically create the virtual attribute 'password confirmation'
validates :password, :presence => true,
:confirmation => true,
:length => { :within => 6..40 }
before_save :encrypt_password
# Return true if the user's password matches the submitted password
def has_password?(submitted_password)
encrypted_password == encrypt(submitted_password)
end
private
def encrypt_password
self.salt = make_salt if new_record?
self.encrypted_password = encrypt(password)
end
def encrypt(string)
secure_hash("#{salt}--#{string}")
end
def make_salt
secure_hash("#{Time.now.utc}--#{password}")
end
def secure_hash(string)
Digest::SHA2.hexdigest(string)
end
end
Все мои RSpec
тесты проходят отлично, и, насколько я могу судить, я дословно закодировал все, что есть в книге — я даже скопировал / вставил некоторый код, чтобы убедиться. Я вообще не вижу никаких причин для сбоя, поэтому любая помощь будет спасением.
Вот ссылка на книгу, онлайн: [ссылка]
Ответ №1:
После вашего вызова create обратите внимание, что возвращаемый объект не имеет идентификатора или зашифрованного пароля… Я подозреваю, что проверка завершается неудачей, и запись не создается, возможно, потому, что у вас уже есть запись?
Комментарии:
1. Большое вам спасибо! Оказывается, ранее я создал запись в базе данных с этой информацией — когда я использовал другую информацию в
:name
и:email:
, это работало отлично! Еще раз спасибо!2. В дополнение к тому, что сказал DGM, вы должны быть в состоянии выполнить
rake db:reset
, а затем попытаться создать свою запись. (Я думаю.)