- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在端口 3101
上运行了一个 Rails 应用程序我通过 Apache 反向代理设置(就像 Phusion 在 this blog post 上建议的那样)将它提供给互联网。
我正在使用 Devise + OmniAuth 来处理 Facebook 身份验证。
但是当我尝试通过 Facebook 进行身份验证时,我被重定向到以下网址:http://mydomain.com:3101/my_callback_path
我用 passenger start -a 127.0.0.1 -p 3101 -d
启动 rails 应用程序我的 Apache 设置是:
<VirtualHost *:80>
ServerName mydomain.com
PassengerEnabled off
ProxyPass / http://127.0.0.1:3101/
ProxyPassReverse / http://127.0.0.1:3101
ProxyRequests Off
ProxyPreserveHost On
<Proxy *>
Order deny,allow
Allow from all
</Proxy>
</VirtualHost>
OmniAuth.config.full_host = 'http://my domain.com'
一起使用但我想知道我的 apache 设置中是否没有缺少配置(如之前的答案)。
最佳答案
我查看了OmniAuth源,发现回调机制内部使用了一个名为full_host
的方法。查找配置变量,然后构建 URI 的第一部分 - 查看 oa-core-0.2.6/lib/omniauth/strategy.rb
配置变量可以是一个字符串(如您的情况)、Proc 或 nil(或其他任何东西)。在后一种情况下,请求 URI 被解析、切碎并返回。
我认为我们不能仅仅通过在 Apache 中设置一个环境变量来解决我们的常见问题(这可能应该在较低的级别完成,在 ruby 应用程序堆栈中),但经过一些实验,我发现这对于我:
OmniAuth.config.full_host = lambda do |env|
scheme = env['rack.url_scheme']
local_host = env['HTTP_HOST']
forwarded_host = env['HTTP_X_FORWARDED_HOST']
forwarded_host.blank? ? "#{scheme}://#{local_host}" : "#{scheme}://#{forwarded_host}"
end
关于ruby-on-rails - OmniAuth 在反向代理设置中使用错误的回调端口,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6803307/
我已经将 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
我是一名优秀的程序员,十分优秀!