【问题标题】:Creation working locally, but not on Heroku. ActiveRecord::UnknownAttributeError (unknown attribute: user_id)创作在本地工作,但不在 Heroku 上。 ActiveRecord::UnknownAttributeError(未知属性:user_id)
【发布时间】:2014-09-16 10:19:43
【问题描述】:

用户只有在登录后才能创建指南。

当我点击“新指南”链接时,Heroku 的日志显示如下:

2013-12-30T20:28:37.826032+00:00 app[web.1]: ActiveRecord::UnknownAttributeError (unknown attribute: user_id):

GuidesController:

class GuidesController < ApplicationController
  before_action :set_guide, only: [:show, :edit, :update, :destroy]
  before_action :authenticate_user!, except: [:index, :show]

  # GET /guides
  # GET /guides.json
  def index
    if params[:tag]
      @guides = Guide.tagged_with(params[:tag])
    else
      @guides = Guide.all
    end

  end

  # GET /guides/1
  # GET /guides/1.json
  def show
  end

  # GET /guides/new
  def new
    @guide = current_user.guides.build(guide_params)
  end

  # GET /guides/1/edit
  def edit
  end

  # POST /guides
  # POST /guides.json
  def create
    @guide = current_user.guides.build(guide_params)

    respond_to do |format|
      if @guide.save
        format.html { redirect_to @guide, notice: 'Guide was successfully created.' }
        format.json { render action: 'show', status: :created, location: @guide }
      else
        format.html { render action: 'new' }
        format.json { render json: @guide.errors, status: :unprocessable_entity }
      end
    end
  end

  # PATCH/PUT /guides/1
  # PATCH/PUT /guides/1.json
  def update
    respond_to do |format|
      if @guide.update(guide_params)
        format.html { redirect_to @guide, notice: 'Guide was successfully updated.' }
        format.json { head :no_content }
      else
        format.html { render action: 'edit' }
        format.json { render json: @guide.errors, status: :unprocessable_entity }
      end
    end
  end

  # DELETE /guides/1
  # DELETE /guides/1.json
  def destroy
    @guide.destroy
    respond_to do |format|
      format.html { redirect_to guides_url }
      format.json { head :no_content }
    end
  end


  private
    # Use callbacks to share common setup or constraints between actions.
    def set_guide
      @guide = Guide.find(params[:id])
    end

    # Never trust parameters from the scary internet, only allow the white list through.
    def guide_params
      params.require(:guide).permit(:title, :author, :description, :link, :tag_list) if params[:guide]
    end
end

【问题讨论】:

  • 您是否遇到任何错误?请提供详细信息以帮助您调试问题。
  • 哦,是的。我怎么会忘记……傻。
  • 已更新。 @SimoneCarletti
  • 你这样做了吗heroku run rake:db migrate
  • @bjhaid - 是的,我有。

标签: ruby-on-rails ruby heroku devise


【解决方案1】:

您的 new 操作中有此内容

def new
  @guide = current_user.guides.build(guide_params)
end

为什么?新操作应该只是将表单返回到浏览器以创建新指南。您在 create 操作中重复此操作,它应该在哪里。

你的index 也有这个:

def index
  if params[:tag]
    @guides = Guide.tagged_with(params[:tag])
  else
    @guides = Guide.all
  end
end

您可能应该使用guide_params[:tag],因为浏览器正在返回:tag

编辑我看到您在白名单中使用了[:tag_list]。我假设您将其交给其他地方?您是否测试过使用定义的标签执行index 操作的能力?我认为您想使用裸params[:xxxx] 的唯一地方是私有方法。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2016-02-08
    • 2016-02-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-01-02
    • 1970-01-01
    相关资源
    最近更新 更多