我对rails有些陌生,我正在try 创建一个用户登录.我浏览了教程,找到了here个.最后,它让我为大规模作业(job)添加了"attr_accessible".然而,当我这样做时,我得到了以下错误:

undefined method `attr_accessible' for #<Class:0x007ff70f276010>

我在这post上看到了我需要的&lt;ActiveRecord::Base.但我也包括在内.以下是我的用户模型的代码:

class User < ActiveRecord::Base

  attr_accessor :password
  EMAIL_REGEX = /\A[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,4}\z/i
  validates :username, :presence => true, :uniqueness => true, :length => { :in => 3..20 }
  validates :email, :presence => true, :uniqueness => true, :format => EMAIL_REGEX
  validates :password, :confirmation => true #password_confirmation attr
  validates_length_of :password, :in => 6..20, :on => :create
  before_save :encrypt_password
  after_save :clear_password
  attr_accessible :username, :email, :password, :password_confirmation

  def encrypt_password
    if password.present?
      self.salt = BCrypt::Engine.generate_salt
      self.encrypted_password= BCrypt::Engine.hash_secret(password, salt)
    end
  end

  def clear_password
    self.password = nil
  end

end

如果您有任何关于导致此问题的其他 idea ,我们将不胜感激,谢谢!

编辑:在Rails 4.1上.看起来已经不适用了.谢谢福塔努斯

推荐答案

Rails 4.1不允许质量分配

不要在模型中使用attr_accessible :username, :email, :password, :password_confirmation,而是使用strong parameters.

    def user_params
      params.require(:user).permit(:username, :email, :password, :password_confirmation)
    end

然后在控制器操作中调用user_params方法.

Ruby-on-rails相关问答推荐

Rails 7通过引擎将方法自动加载到控制器中的方法

在VP中部署rails 7和nginx

在数组中定位不匹配的索引

Rails 6升级没有加载Mongoid,这是一个问题

SASS,Rails 7:找不到要导入的样式表

我可以向 erb 变量插值添加一个类吗?

如何将实例变量传递给 RSpec 共享示例

安装mysql2(0.4.8)时出错,Bundler无法继续

了解 Rails 验证:allow_blank 有什么作用?

带有 master.key 的 Rails 5.2 - Heroku 部署

如何在 Rails 1.2.3 中使复选框默认为选中?

如何将 ActionMailer default_url_options 的 :host 动态设置为请求的主机名?

我可以在 twitter-bootstrap popover 数据内容中使用 html 标签吗?

在 rails 3 中批量插入

如何打印出范围之间的随机数?

submit_tag rails 表单中的 bootstrap 图标

从任何编码强制字符串为 UTF-8

如何从另一个调用 Capistrano 任务?

从 Rails 中的 ActiveRecord::RecordNotFound 救援

如何在 Rails 3 中订购包含的元素