我使用https://github.com/plataformatec/devise/wiki/OmniAuth%3a-Overview整合了omniauth-facebook。但我得到的错误是:
Could not authenticate you from Facebook because "Invalid credentials".
在日志中,得到这个:
Authentication failure! invalid_credentials: OAuth2::Error, : {"error":{"message":"This authorization code has been used.","type":"OAuthException","code":100}}
我已经安装好了。当我点击Facebook登录链接时,它会回来设计标志“www.mealnut.com/user/sign_in# = ”并给出上述错误。我在https://github.com/plataformatec/devise/wiki/OmniAuth%3a-Overview检查了“无效凭据”的解决方案,正如那里提到的,我的应用程序是为App Type = Web设置的标头。不明白为什么它不起作用。
我的应用程序正在等待来自facebook的评论。但我不认为这与此错误有关。以下是我为omniauth-facebook所做的事情:
Gemfile包含:
gem "omniauth", "~> 1.1.4"
gem 'omniauth-facebook', '1.4.1'
在用户模型中,添加:
devise :omniauthable, :omniauth_providers => [:facebook]
attr_accessible :provider, :uid
def self.find_for_facebook_oauth(auth, signed_in_resource=nil)
user = User.where(:provider => auth.provider, :uid => auth.uid).first
unless user
user = User.create(name:auth.extra.raw_info.name,
provider:auth.provider,
uid:auth.uid,
email:auth.info.email,
password:Devise.friendly_token[0,20]
)
end
user
end
devise.rb
require "omniauth-facebook"
config.omniauth :facebook, "APP_ID", "APP_SECRET", :scope => "offline_access, email"
omniauth.rb:
OmniAuth.config.logger = Rails.logger
Rails.application.config.middleware.use OmniAuth::Builder do
provider :facebook, ENV['FACEBOOK_KEY'], ENV['FACEBOOK_SECRET'], {:provider_ignores_state => true}
end
route.rb:
devise_for:user,:controllers => {:omniauth_callbacks => “omniauth_callbacks”}
Omniauth控制器:
class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
def facebook
@user = User.find_for_facebook_oauth(request.env["omniauth.auth"], current_user)
if @user.persisted?
sign_in_and_redirect @user, :event => :authentication #this will throw if @user is not activated
set_flash_message(:notice, :success, :kind => "Facebook") if is_navigational_format?
else
session["devise.facebook_data"] = request.env["omniauth.auth"]
redirect_to new_user_registration_url
end
end
end
有人可以帮忙吗?
答案 0 :(得分:37)
我想知道我在这里筹码,因为当我试图搜索的解决方案时,我想到了这个问题,因为“凭证无效”
问题在于Facebook API版本&gt; = 2.3您需要将{token_params: {parse: :json}}
设置为您的提供商配置。
devise.rb
config.omniauth :facebook,
APP_ID,
APP_SECRET,
token_params: { parse: :json } # <----- this line is NB
在omniauth-oauth2
上找到token_params
更新2018年8月:&#34;无效凭据&#34;问题再次发生,我不得不删除composer dump-autoload
设置以便再次使用 - 所以这可能不再是问题了
答案 1 :(得分:5)
搞定了!
我的routes.rb和user.rb错了。并改变了omniauth.rb!这是前一个和后一个文件:
我的routes.rb是:
devise_for :user, :controllers => { :registration => "registration" }
devise_for :user, :controllers => { :omniauth_callbacks => "omniauth_callbacks" }
所以它是两次调用设计。我改成了:
devise_for :user, :controllers => { :registration => "registration", :omniauth_callbacks => "omniauth_callbacks" }
将omniauth.rb改为:
OmniAuth.config.logger = Rails.logger
Rails.application.config.middleware.use OmniAuth::Builder do
provider :facebook, ENV['FACEBOOK_KEY'], ENV['FACEBOOK_SECRET'], {:provider_ignores_state => true}
end
到此:
OmniAuth.config.logger = Rails.logger
另外,我在user.rb模型(重大错误)之外定义了方法“def self.find_for_facebook_oauth(auth,signed_in_resource = nil)”。
现在让它完美运作: - )
希望这有助于某人。
答案 2 :(得分:2)
得到了它的工作:) 我们不需要在omniauth.rb
中添加此代码Rails.application.config.middleware.use OmniAuth::Builder do
provider :facebook, ENV['FACEBOOK_KEY'], ENV['FACEBOOK_SECRET']
end
如果我们已经在devise.rb中声明它
require "omniauth-facebook"
config.omniauth :facebook, "APP_ID", "APP_SECRET"
答案 3 :(得分:0)
它帮助我解决了类似的问题:
注意:v2.0.1存在回调网址错误的问题。您需要在config上添加回调网址。
config.omniauth :facebook, "APP_ID", "APP_SECRET",
callback_url: "CALLBACK_URL"
https://github.com/plataformatec/devise/wiki/OmniAuth%3a-Overview
答案 4 :(得分:0)
将gem升级到4.0.0并将require "omniauth-facebook"
添加到devise.rb
为我修复此问题。
答案 5 :(得分:0)
我遇到了这个问题,没有人提出建议。 问题出在redirect_uri中。设计omniauth gems生成了没有http s 的
。最后通过两个步骤解决了这个问题: