1

我在 Rails 控制台中遇到了错误。我正在使用最新版本的 Rails 和 Pry。我正在尝试生成用户。我可以在用户属性中设置值,但无法保存它们。也许 User.new 在某个地方循环?这是我的模型的属性相关代码:

require 'bcrypt'
class User < ActiveRecord::Base

attr_accessible :first_name, :last_name, :description, :profile_photo, :password, :password_confirmation, :email
attr_reader :password

has_secure_password

validates_presence_of :email, :session_token, :first_name, :last_name, :password_digest
validates_uniqueness_of :email
validates :password, length: { minimum: 6, maximum: 20 } 

before_validation :reset_session_token!, on: :create
before_save :encrypt_new_password

这是我的用户迁移:

class CreateUsers < ActiveRecord::Migration
def change
 create_table :users do |t|
  t.string  :email, unique: true, null: false
  t.string  :password_digest, null: false
  t.string  :first_name, null: false
  t.string  :last_name, null: false
  t.string  :description, limit: 400
  t.string  :session_token, null: false
  t.attachment :profile_photo
  t.integer :profile_photo_id
  t.datetime :profile_photo_updated_at

  t.timestamps
end

  add_index :users, :email
  add_index :users, :first_name
  add_index :users, :last_name
  add_index :users, :session_token
  add_index :users, :created_at
 end
end

在尝试通过User.new(values)然后.saveUser.create(values)u = User.new然后u.value = value然后u.save创建用户后,这是我的 Rails 控制台错误。

[10] pry(User):1> u.save
(0.2ms)  BEGIN
(0.2ms)  ROLLBACK
SystemStackError: stack level too deep
from /Users/joecase/.rvm/gems/ruby-2.1.0/gems/pry-0.9.12.6/lib/pry/pry_instance.rb:328
[11] pry(User):1> u.errors
=> #<ActiveModel::Errors:0x0000010527ccb0
@base=
#<User id: nil, email: "joecase@nyu.edu", password_digest: "111111", first_name: "Joe", last_name: "Case", description: nil, session_token: "CVnrsyyTwoOp9TZkqmVfTw", profile_photo_file_name: nil, profile_photo_content_type: nil, profile_photo_file_size: nil, profile_photo_updated_at: nil, profile_photo_id: nil, created_at: nil, updated_at: nil>,
@messages={}>

[12] pry(User):1> u.errors.full_messages
=> []

任何帮助,将不胜感激。先感谢您。

加密新密码:

def encrypt_new_password
  return if password.blank?
  self.hashed_password = encrypt(password)
end

重置会话令牌:

 def reset_session_token
   self.session_token ||= SecureRandom.urlsafe_base64(16)
   save!
 end
4

2 回答 2

0

很可能,问题出在回调函数 before_save :encrypt_new_password 中。

如果函数 :encrypt_new_password 尝试更新和保存用户记录,您将面临这个问题,如果您可以编辑您的问题并发布 :encrypt_new_password 函数会很好,因为它是最有可能导致无限回调的函数。

查看为回调提供的两个函数,问题出在用于验证的回调函数中。

def reset_session_token
   self.session_token ||= SecureRandom.urlsafe_base64(16)
   save!
end

在您保存将验证的验证之前以及在您保存的验证之前等等。因此,尝试散列保存!调用它应该被保存,如果不尝试使其成为 after_validation 回调。

于 2014-02-17T18:27:38.520 回答
0

也许您在回调 reset_session_token 中调用了一些混淆!但是没有感叹号的定义方法?虽然没有其他想法。

于 2014-02-18T12:03:43.947 回答