我对以下错误感到疯狂。我有一个User类,它的两个属性(birthday& created_at => datetime)总是返回nil,除了它在数据库上有一个值。
我正在使用设计来管理身份验证。
这是db表:
CREATE TABLE users
(
id serial NOT NULL,
email character varying(255) NOT NULL DEFAULT ''::character varying,
encrypted_password character varying(255) NOT NULL DEFAULT ''::character varying,
reset_password_token character varying(255),
reset_password_sent_at timestamp without time zone,
remember_created_at timestamp without time zone,
sign_in_count integer NOT NULL DEFAULT 0,
current_sign_in_at timestamp without time zone,
last_sign_in_at timestamp without time zone,
current_sign_in_ip character varying(255),
last_sign_in_ip character varying(255),
name character varying(255),
lastname character varying(255),
birthday timestamp without time zone,
gender character varying(255),
created_at timestamp without time zone,
updated_at timestamp without time zone,
authentication_token character varying(255),
facebook_uid character varying(255),
gplus_uid character varying(255),
CONSTRAINT users_pkey PRIMARY KEY (id)
)
WITH (
OIDS=FALSE
);
这是模型
#encoding: utf-8
class User < ActiveRecord::Base
has_many :user_benefits
has_many :benefits, through: :user_benefits
devise :database_authenticatable, :registerable,
:recoverable, :rememberable, :trackable, :validatable
validates :gender, :inclusion => { :in => %w(m f)}
validates :email, email_format: { message: "Email invalido" }
before_save :ensure_authentication_token
def ensure_authentication_token
if authentication_token.blank?
self.authentication_token = generate_authentication_token
end
end
def set_gender new_gender
case new_gender.downcase
when "male"
self.gender = 'm'
when "female"
self.gender = 'f'
when "m"
self.gender = 'm'
when "f"
self.gender = 'f'
else
self.gender = nil
end
end
def get_response
{
:auth_token=>self.authentication_token,
:user => {
:email=> self.email,
:name=> self.name,
:lastname=> self.lastname,
:birthday=> self.birthday,
:gender=> self.gender,
:auth_token=> self.authentication_token,
:created_at=> self.created_at,
:updated_at=> self.updated_at,
:facebook_uid=> self.facebook_uid,
:gplus_uid=> self.gplus_uid
}
}
end
private
def generate_authentication_token
loop do
token = Devise.friendly_token
break token unless User.where(authentication_token: token).first
end
end
end
当我打电话给get_response时,我得到了:
{
auth_token: "fRoi1RPTuP64m55jXCSS"
user: {
email: "testg@habitues.com"
name: "Lalo"
lastname: "Landa"
birthday: null
gender: "m"
auth_token: "fRoi1RPTuP64m55jXCSS"
created_at: null
updated_at: "2013-11-27T20:14:22.534-03:00"
facebook_uid: null
gplus_uid: null
}
new: false
}
有人有想法吗?
感谢
答案 0 :(得分:5)
config.active_record.default_timezone
需要一个符号:local或:utc。
config.time_zone
需要一个常规的时区。
config.active_record.default_timezone
确定从数据库中提取日期和时间时是否使用Time.local(如果设置为:local)或Time.utc(如果设置为:utc)。默认值为:utc。
http://guides.rubyonrails.org/configuring.html#configuring-active-record
答案 1 :(得分:3)
我发现了问题。
前几天我更改了config / application.rb文件,添加了以下配置来解决时区的一些问题:
config.time_zone and config.active_record.default_timezone
我刚删除它们,一切都恢复正常。
答案 2 :(得分:3)
有同样的问题,具体是
config.active_record.default_timezone
这导致activerecord将所有UTC存储的时间戳返回为null。不知道为什么,但删除它带回了所有数据。我能够保留默认的config.time_zone。