我在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
答案 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中有一些混乱!但定义没有标记的方法?没有其他的想法。