时区差异

时间:2019-12-29 13:27:09

标签: ruby-on-rails ruby time

我正在尝试使用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
>> 

为什么?

1 个答案:

答案 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