Rails 5 ActionController::InvalidAuthenticityToken 错误

Posted

技术标签:

【中文标题】Rails 5 ActionController::InvalidAuthenticityToken 错误【英文标题】:Rails 5 ActionController::InvalidAuthenticityToken error 【发布时间】:2016-11-14 20:23:57 【问题描述】:

我有一个 rails 应用程序,我计划升级到 rails 5。我正在使用 devise(v4.2.0) 和 rails(v5.0.0)。正如设计 README.md 文件中所建议的那样,我尝试将protect_from_forgery 移到 before_filter 上方,但是当我尝试登录或更新我的错误时,我仍然收到错误ActionController::InvalidAuthenticityToken

我的Application Controller

class ApplicationController < ActionController::Base
 protect_from_forgery with: :exception, prepend: true
 before_action :configure_permitted_parameters, if: :devise_controller?

  protected

   def configure_permitted_parameters
     devise_parameter_sanitizer.permit(:sign_up, keys: [:name])
     devise_parameter_sanitizer.permit(:account_update, keys: [:name])
   end

end

而我的另一个BugController

class BugsController < ApplicationController
  protect_from_forgery prepend: true, with: :exception
  before_action :authenticate_user!
  before_action :set_bug, only: [:show, :edit, :update]

    def update
      respond_to do |format|
      if @bug.update(bug_params)
        format.html  redirect_to @bug, notice: 'Bug was successfully updated.' 
        format.json  render :show, status: :ok, location: @bug 
     else
        format.html  render :edit 
        format.json  render json: @bug.errors, status: :unprocessable_entity 
     end
     end
   end

private
def bug_params
  params.require(:bug).permit(:product, :component, :title, :description, :status_id, :created_by_id, :assigned_to_id)
end


end

【问题讨论】:

【参考方案1】:

这个决定帮助了我。我 [从这里] [1] 做出了决定。就我而言,该主题的不幸名称,使用错误的关键字我没有到达那里,所以我会在这个线程中给出,因为这是错误的确切名称。 就我而言,我在application_controller.rb 文件中“添加”了以下行:

protect_from_forgery with:: null_session

有一个解决方案,上面写着“REPLACE”行protect_from_forgery with:: exception,如果存在的话,就是我上面引用的那个

   [1]:Rails 4 Authenticity Token

【讨论】:

【参考方案2】:

注意:虽然此答案具有预期的效果,但它会降低整体安全性。 Alon 的以下回答更正确,并维护了网站的安全性。

class BugsController < ApplicationController
skip_before_filter :verify_authenticity_token
protect_from_forgery prepend: true, with: :exception
before_action :authenticate_user!
before_action :set_bug, only: [:show, :edit, :update]
end

喜欢这个

【讨论】:

我尝试将skip_before_filter :verify_authenticity_token 放入错误控制器,但仍然无法正常工作。 Bugs controllerprotect_from_forgery prepend: true, with: :exception before_action :authenticate_user! before_action :set_bug, only: [:show, :edit, :update] 尝试了您提供的答案,但我仍然收到错误ActionController::InvalidAuthenticityToken in BugsController#update 把它放到应用控制器上 最好使用skip_before_action而不是skip_before_filter...【参考方案3】:

我最近以相当大的方式遇到了这个问题,我发现我的错误是我的应用程序的域名最近更改了,但我忘记更新 session_store.rb。这可能不是每个人的问题,但它会将此报告为 CSRF 错误。所以请查看 config/session_store.rb

【讨论】:

我相信它是 config/initializers/session_store.rb【参考方案4】:

我用过类似的东西,它对我有用。

class WelcomeController < ActionController::Base
    protect_from_forgery with: :exception
    before_action :authenticate_model!
end

【讨论】:

【参考方案5】:

如Devise documentation Rails 5 注释中所述

对于 Rails 5,请注意 protect_from_forgery 不再是前置 到before_action 链,所以如果你设置了authenticate_userprotect_from_forgery 之前,您的请求将导致“不能 验证 CSRF 令牌的真实性。”要解决此问题,请更改 您调用它们的顺序,或使用protect_from_forgery prepend: true

【讨论】:

这似乎是比跳过真实性令牌验证更好的选择!! 这应该是选择的答案 这个解决方案对我也有帮助。我有带有 SSL 和 Route53 的 AWS CloudFront,我遇到了类似的问题:我正在向 rails 应用程序发送发布请求(没有登录的反馈表单),并且通过 http 没有 CSRF 令牌一切正常,但是通过 SSL 的pitost 没有工作。我需要在云端添加自定义原始标头以解决问题Origin header didn't match request.base_url,然后我遇到问题Can't verify CSRF token authenticity,当我向请求添加令牌并添加标头'X-CSRF-Token': authenticity_token 时我遇到问题InvalidAuthenticityToken,这个解决方案帮助了我 谢谢!这很简单。 这也适用于 rails 6 吗?

以上是关于Rails 5 ActionController::InvalidAuthenticityToken 错误的主要内容,如果未能解决你的问题,请参考以下文章

简单 Rails 4 ActionController::Live 示例不适用于 Apache + Passenger

Rails 6 - 常量 ActionController::InvalidAuthenticityToken

Rails 5 API 不生成视图

Rails 部分更新 ActionController::UnknownFormat

在 Rails 4 中救援来自 ActionController::RoutingError

对选择 Faye 或 Rails 4 Actioncontroller::Live 的困惑