Rails控制台:用户无法保存 - 堆栈级别太深

时间:2014-02-17 18:01:25

标签: mysql ruby-on-rails ruby irb bcrypt-ruby

我在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(值)然后 .save 用户创建用户后,我的Rails控制台错误。创建(值),或 u = User.new ,然后 u.value = value ,然后 u.save

[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
=> []

任何帮助将不胜感激。提前谢谢。

encrypt_new_password:

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

reset_session_token:

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

2 个答案:

答案 0 :(得分: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回调。

答案 1 :(得分:0)

也许你在回调reset_session_token中有一些混乱!但定义没有标记的方法?没有其他的想法。