ruby on rails - ونينتياليزد ثابت أبليكاتيونريكورد




ruby-on-rails ruby-on-rails-4 (2)

أنا أعمل على القضبان كتاب تعليمي على الانترنت، وأنا الحصول على رسالة الخطأ التالية عندما أذهب إلى هتب: // لوكالهوست: 3000 /

"أوننيتياليزد ثابت تطبيق التسجيل"

ويعطيني التعليمات البرمجية التالية تسليط الضوء على السطر الأول.

class User < ApplicationRecord
  attr_accessor :remember_token
  before_save { self.email = email.downcase }
  validates :name,  presence: true, length: { maximum: 50 }
  VALID_EMAIL_REGEX = /\A[\w+\-.][email protected][a-z\d\-.]+\.[a-z]+\z/i
  validates :email, presence: true, length: { maximum: 255 },

في ما يلي ملف application.html.erb:

<!DOCTYPE html>
<html>
  <head>
    <title><%= full_title(yield(:title)) %></title>
    <%= stylesheet_link_tag "application", media: "all",
                                           "data-turbolinks-track" => true %>
    <%= javascript_include_tag "application", "data-turbolinks-track" => true %>
    <%= csrf_meta_tags %>
    <%= render 'layouts/shim' %>
  </head>
  <body>
    <%= render 'layouts/header' %>
    <div class="container">
      <% flash.each do |message_type, message| %>
        <div class="alert alert-<%= message_type %>"><%= message %></div>
      <% end %>
      <%= yield %>
      <%= render 'layouts/footer' %>
      <%= debug(params) if Rails.env.development? %>
    </div>
  </body>
</html>

وملف user.rb الخاص بي:

class User < ApplicationRecord
  attr_accessor :remember_token
  before_save { self.email = email.downcase }
  validates :name,  presence: true, length: { maximum: 50 }
  VALID_EMAIL_REGEX = /\A[\w+\-.][email protected][a-z\d\-.]+\.[a-z]+\z/i
  validates :email, presence: true, length: { maximum: 255 },
                    format: { with: VALID_EMAIL_REGEX },
                    uniqueness: { case_sensitive: false }
  has_secure_password
  validates :password, presence: true, length: { minimum: 6 }

  # Returns the hash digest of the given string.
  def User.digest(string)
    cost = ActiveModel::SecurePassword.min_cost ? BCrypt::Engine::MIN_COST :
                                                  BCrypt::Engine.cost
    BCrypt::Password.create(string, cost: cost)
  end

  # Returns a random token.
  def User.new_token
    SecureRandom.urlsafe_base64
  end

  # Remembers a user in the database for use in persistent sessions.
  def remember
    self.remember_token = User.new_token
    update_attribute(:remember_digest, User.digest(remember_token))
  end

  # Returns true if the given token matches the digest.
  def authenticated?(remember_token)
    return false if remember_digest.nil?
    BCrypt::Password.new(remember_digest).is_password?(remember_token)
  end

  # Forgets a user.
  def forget
    update_attribute(:remember_digest, nil)
  end
end


يبدو أنك تستخدم القضبان 5 البرنامج التعليمي، ولكن العمل مع القضبان 4. في القضبان 5 جميع النماذج ترث من ApplicationRecord ، في حين القضبان 4 من ActiveRecord::Base

الإصلاح الفوري:

class User < ActiveRecord::Base
...
end

إصلاح على المدى الطويل، والتحول إلى القضبان 5 والتعلم مع القضبان 5


مشيرا إلى إجابة غارقة من https://.com/a/41388844/5598043

إنشاء ملف جديد يسمى التطبيق / نماذج / application_record.rb مع المحتويات التالية:

كلاس أبليكاتيونريكورد <أكتيفريكورد :: قاعدة self.abstract_class = نهاية حقيقية







railstutorial.org