我正在尝试使用Rails教程开发应用程序。 我在第十二章中,遇到麻烦了。 当我从密码重设表单发送电子邮件时,reset_at时间添加了错误的时间。 在控制台中,我可以获得正确的时间。 有谁可以帮助我吗?谢谢。
models / user.rb
def create_reset_digest
self.reset_token = User.new_token
update_attribute(:reset_digest, User.digest(reset_token))
update_attribute(:reset_sent_at, Time.zone.now)
end
在控制台中(“ reset_sent_at”是错误的时间)
>> User.first
User Load (0.2ms) SELECT "users".* FROM "users" ORDER BY "users"."id" ASC LIMIT ? [["LIMIT", 1]]
=> #<User id: 1, name: "Example User", email: "example@railstutorial.org", created_at: "2019-12-27 19:18:17", updated_at: "2019-12-29 13:03:12", password_digest: "$2a$10$jbZmEQiB6reX6e/ieGC4wu1lVALDE0GHlkPPeIbUaGe...", remember_`enter code here`digest: nil, admin: true, activation_digest: "$2a$10$t2pk3NPXsvpYcVlrnB4nh.jOZu4YEyKih5wMqneuia2...", activated: true, activated_at: "2019-12-27 19:18:17", reset_digest: "$2a$10$UExX5u5qsCrwuCzyz5xicObm9w98.XWHQuxoDT7vlzC...", reset_sent_at: "2000-01-01 13:03:12">
在控制台中(我可以得到正确的时间)
Time.zone.now
=> Sun, 29 Dec 2019 22:23:40 JST +09:00
>>
为什么?
答案 0 :(得分:-1)
我解决了这个问题。 像下面这样向用户表添加列时,我只是犯了一个错误。
class AddAdtivationToUsers < ActiveRecord::Migration[5.1]
def change
add_column :users, :activation_digest, :string
add_column :users, :activated, :boolean, default: false
add_column :users, :activated_at, :datatime # here is the point of mistake.
# I should have write ":datetime"
end
end