- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 omniauth和 omniauth-identity用于通过 Google、Facebook 和传统用户名/密码进行身份验证。除了身份验证失败的情况外,我的所有工作都很好。失败时,例如输入无效密码时,omniauth 将调用 /auth/failure
.我已经将它映射到一个 Controller ,该 Controller 重定向到一个适当的页面并显示一个 flash 消息。我遇到的问题是我无法让闪光灯实际显示。示例代码:
在 routes.rb
:
match "/auth/failure" => "sessions#failure"
def failure
redirect_to root_url, alert: "Authentication failed, please try again."
end
最佳答案
我在上一个项目中遇到了同样的问题。这是一个错误。将以下猴子补丁添加到您的 config/initializers/omniauth.rb
# Omniauth failure monkey patch
on_failure do |env|
message_key = env['omniauth.error.type']
origin_query_param = env['omniauth.origin'] ? "&origin=#{CGI.escape(env['omniauth.origin'])}" : ""
strategy_name_query_param = env['omniauth.error.strategy'] ? "&strategy=#{env['omniauth.error.strategy'].name}" : ""
extra_params = env['omniauth.params'] ? "&#{env['omniauth.params'].to_query}" : ""
new_path = "#{env['SCRIPT_NAME']}#{OmniAuth.config.path_prefix}/failure?message=#{message_key}#{origin_query_param}#{strategy_name_query_param}#{extra_params}"
Rack::Response.new(["302 Moved"], 302, 'Location' => new_path).finish
end
关于ruby-on-rails - Omniauth 认证失败回调处理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14743471/
我已经将 gitlab 全部设置好并准备好omniauth,我想知道是否可以完全禁用使用密码和用户名的默认身份验证并仅使用omniauth(在我们的例子中为google登录)。我希望通过将 Googl
我是 Rails 和 Omniauth 的新手,所以提前为愚蠢的人感到抱歉 题。 我正在尝试为 Deezer 网站制定 Omniauth 策略。 http://www.deezer.com/en/de
所以我试图让 omniauth-facebook 在我的生产环境中工作。它使用 POW 在我的机器上本地运行良好。 我的产品环境是带有 nginx/unicorn 的 ubuntu,代码是 Rails
嗨,我正在学习如何使用omniauth 作为 ember 应用程序的后端。 当我运行我的应用程序时,我得到下面提到的错误 OmniAuth::NoSessionError - 您必须提供 sessio
我正在使用: Ruby on Rails 4 设计 3.0.3 omniauth (1.1.4) omniauth-facebook (1.4.1) omniauth-twitter (1.0.0)
如果我使用 omniauth 进行 Twitter 验证.. 下面的代码是 def create user = User.from_omniauth(env["omniauth.auth"])
再具体一点: 如果我打电话,我的 Rails 应用程序运行良好 /auth/facebook/callback或 /auth/facebook/callback?format=json 但是当我尝试打
在我的项目中,我有两类用户:求职者和招聘经理。求职者没有模型,他们只能使用从第三方供应商处收到的数据申请工作,同时通过 Omniauth 进行身份验证。招聘经理的信息存储在设计用户模型中。招聘经理还必
我正在尝试在 Rails 3.2.9 中使用 omniauth-facebook 登录 Facebook;我遵循了 Ryan Bates 在 http://railscasts.com/episode
我一直在探索我的 Rails 应用程序的身份验证选项。我需要用户名/密码身份验证以及将用户与其 Facebook、Twitter、Foursquare 等身份链接的选项。我通常会发现人们为此目的使用
关于如何记住我与 Omniauth 一起工作似乎有些困惑。 根据这个wiki ,您需要在 OmniauthCallbacksController 中包含以下内容: remember_me(user)
说我有用户和项目模型。用户和项目与HABTM相关。我的设置实际上比这要复杂一些,但是出于我的问题,我认为这可以做到。 现在,我想使用omniauth通过Twitter,Facebook来验证特定项目,
我正在尝试使用 omniauth 测试一个简单的 facebook 登录。但是,收到一条错误消息,指出“auth”未定义 variable 或 method。 omniauth 测试文档不包含 fac
我在 Twitter 上使用 gem。回调时,检查用户是否存在并创建他或将他发送回主页。 我可能做错了什么,但在我的回调代码中, request.env['omniauth.origin'] 为零 .
我将 OmniAuth 与 Devise 结合使用,以允许用户使用 facebook 登录或使用用户名和密码创建普通帐户。当我最初设置它时,我使用了来自 Railscasts 的优秀指导。 .在 2
我在端口 3101 上运行了一个 Rails 应用程序我通过 Apache 反向代理设置(就像 Phusion 在 this blog post 上建议的那样)将它提供给互联网。 我正在使用 Devi
我正在开发一个 Rails 3.0 应用程序并使用 OmniAuth + Identity 来验证注册。我已经实现了一个通过外键与身份模型相关联的用户模型,并且一切运行良好。现在,我想实现一个忘记密码
我有一个 Rails 应用程序设置为 OAuth2 提供程序(使用 Doorkeeper)。该应用程序为每个用户帐户使用不同的子域(或通过 cname 记录使用完全不同的域) i.e. user1.m
我正在使用 omniauth和 omniauth-identity用于通过 Google、Facebook 和传统用户名/密码进行身份验证。除了身份验证失败的情况外,我的所有工作都很好。失败时,例如输
我正在构建一个网站,并添加了“使用 Slack 登录”按钮。 我正在使用 omniauth-slack(最新的 8b2371),它运行良好。 但我只想允许来自我自己的 Slack 团队的用户。 有te
我是一名优秀的程序员,十分优秀!