0

当我从下面的 job.rb 模型中删除 Devise 模块时,jobs_controller.rb 出现问题:

class Job < ActiveRecord::Base

# Include default devise modules. Others available are:
# :token_authenticatable, :confirmable,
# :lockable, :timeoutable and :omniauthable

    devise  :database_authenticatable,
            :recoverable, :rememberable, :trackable, :validatable

# Setup accessible (or protected) attributes for your model
attr_accessible :contact_email, :contact_phone, :description, :district, :due_date, :expiration_date, :job_title, :posting_date, :requirements, :salary, :submission_process

end

然后我删除了 Devise 模块,并得到了结果模型:

class Job < ActiveRecord::Base

    # Setup accessible (or protected) attributes for your model
attr_accessible :contact_email, :contact_phone, :description, :district, :due_date,       :expiration_date, :job_title, :posting_date, :requirements, :salary, :submission_process

end

进行此转换时引发的错误显示在以下跟踪中:

ActiveRecord::StatementInvalid in JobsController#create

SQLite3::ConstraintException: constraint failed: INSERT INTO "jobs" ("contact_email",     "contact_phone", "created_at", "current_sign_in_at", "current_sign_in_ip", "description", "district", "due_date", "email", "encrypted_password", "expiration_date", "job_title", "last_sign_in_at", "last_sign_in_ip", "posting_date", "remember_created_at", "requirements", "reset_password_sent_at", "reset_password_token", "salary", "sign_in_count", "submission_process", "updated_at") VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)

app/controllers/jobs_controller.rb:49:in `block in create'
app/controllers/jobs_controller.rb:48:in `create'

我有一个用户模型和一个工作模型,该应用程序由一个基本的脚手架组成,允许用户发布和查看工作,这取决于使用 Devise 的正确身份验证。我对适当的后端构造相对较新,并且在前端视图类型 Rails 方面有更多经验。我不确定我是否需要在 Job 模型中或仅在 User 模型中存在 Devise。

4

1 回答 1

0

一般来说,这样的异常意味着您违反了数据库约束。对您的表执行 NOT NULL、UNIQUE 或其他类型的数据库。

例如,Devise 强制电子邮件和加密密码等字段不能为空。您可以查看db/schema.rb为您的表构建的约束和索引。

在这种情况下,您很可能没有填充encrypted_password属性和/或您正在插入重复的电子邮件。如果需要,您可以通过迁移移除这些约束

编辑:在回答您的第二个问题时,您只需要设计您的用户进行身份验证的模型(将存储他们的密码)。然后,为了强制用户只能创建和编辑属于他们的作业,请在您的控制器中说:before_filter :authenticate_user!在您的个人操作(或另一个 before_filter)中,您检查他们尝试编辑的作业是否属于他们。

于 2012-06-21T21:00:32.337 回答