首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails 4 before_create方法未保存到DB

Rails 4 before_create方法未保存到DB
EN

Stack Overflow用户
提问于 2015-12-09 05:24:57
回答 2查看 339关注 0票数 0

每次将Post请求发送到URLwww.example.com/emailsig.json时,我都试图为SQL创建一个新的散列令牌。我使用before_create运行一个函数,这个函数正在被调用,但是函数中创建的变量没有保存到DB中。我刚开始使用rails,不知道从哪里开始解决这个问题。我认为这可能与强参数有关?

Rails模型

代码语言:javascript
复制
class Distribution < ActiveRecord::Base
  belongs_to :user
  #validates :distribution_digest, presence: true
  attr_accessor :distribution_token, :distribution_digest
  before_create :create_distribution_digest
  validates :signature_id, presence: true

  def Distribution.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 Distribution.new_token
    SecureRandom.urlsafe_base64
  end

  private

    # Creates and assigns the distribution token and digest.
    # Functions create tokens and hashed tokens as expected.
    def create_distribution_digest
      self.distribution_token  = Distribution.new_token
      self.distribution_digest = Distribution.digest(distribution_token)
    end
end

Rails控制器

代码语言:javascript
复制
class DistributionsController < ApplicationController
  before_action :logged_in_user, only: [:email_sig]

  def create
    if current_user.microposts.find(params[:signature_id])
      @distribution = current_user.distributions.build(distribution_params)
      @distribution.save
      respond_with current_user.microposts.find(params[:signature_id])
    end
  end

  private

    def distribution_params
      params.require(:distribution).permit(:signature_id).merge(:distributed_at => Time.zone.now)
    end

end

服务器日志

代码语言:javascript
复制
Started POST "/emailSig.json" for 180.181.247.76 at 2015-12-09 05:01:47 +0000
Processing by DistributionsController#create as JSON
  Parameters: {"signature_id"=>8, "distribution"=>{"signature_id"=>8}}
  User Load (0.5ms)  SELECT  "users".* FROM "users" WHERE "users"."id" = ? LIMIT 1  [["id", 2]]
  Micropost Load (3.2ms)  SELECT  "microposts".* FROM "microposts" WHERE "microposts"."user_id" = ? AND "microposts"."id" = ?  ORDER BY "microposts"."created_at" DESC LIMIT 1  [["user_id", 2], ["id", 8]]
   (0.2ms)  begin transaction
blah
pW00Dn7L9p7CnC6BysvImQ
  SQL (1.0ms)  INSERT INTO "distributions" ("signature_id", "distributed_at", "user_id", "created_at", "updated_at") VALUES (?, ?, ?, ?, ?)  [["signature_id", "8"], ["distributed_at", "2015-12-09 05:01:48.469044"], ["user_id", 2], ["created_at", "2015-12-09 05:01:48.484218"], ["updated_at", "2015-12-09 05:01:48.484218"]]
   (11.8ms)  commit transaction

控制台查询(将distribution_digest显示为零)

代码语言:javascript
复制
  Distribution.last
  Distribution Load (0.4ms)  SELECT  "distributions".* FROM "distributions"  ORDER BY "distributions"."id" DESC LIMIT 1
=> #<Distribution id: 27, user_id: 2, signature_id: "8", distribution_digest: nil, distributed_at: "2015-12-09 05:01:48", created_at: "2015-12-09 05:01:48", updated_at: "2015-12-09 05:01:48">
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-12-09 06:17:13

列名中的保留字digest似乎导致了这个问题。我试图将该列重命名为sth_else,并且所有内容都正常工作,但是使用distribution_digest,我甚至不能在rails控制台中添加这个属性。尝试重命名该列,它将开始工作:)

票数 0
EN

Stack Overflow用户

发布于 2018-02-21 18:19:50

我是通过从:distribution_digest中删除attr_accessor来完成这个任务的。

attr_accessor是用于(快速)在类中创建setter和getter方法的红宝石代码。就这样。 现在,所缺少的解释是,当您用数据库表在(Rails)模型之间创建链接时,您永远不需要模型中的attr_accessor来创建setter和getter,以便能够修改表的记录。

https://stackoverflow.com/a/12938809

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34171329

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档