Szyny: Nie można uwierzytelnić Cię z Facebooka, ponieważ „Nieprawidłowe dane uwierzytelniające”

Zintegrowałem korzystanie z omniauth-facebookhttps://github.com/plataformatec/devise/wiki/OmniAuth%3a-Overview. Ale dostaję błąd:

Could not authenticate you from Facebook because "Invalid credentials".

I w dziennikach, uzyskując to:

Authentication failure! invalid_credentials: OAuth2::Error, : {"error":{"message":"This authorization code has been used.","type":"OAuthException","code":100}}

Mam zainstalowany. Po kliknięciu linku do logowania na Facebooku wraca do nowego znaku „www.mealnut.com/user/sign_in#=„i podaje powyższy błąd. Sprawdziłem rozwiązanie„ Nieprawidłowe poświadczenia ”https://github.com/plataformatec/devise/wiki/OmniAuth%3a-Overview i jak już wspomniano, moja aplikacja jest ustawiona na nagłówek App Type = Web. Nie rozumiem, dlaczego nie działa.

Również moja aplikacja oczekuje na sprawdzenie z Facebooka. Ale nie sądzę, że jest to związane z tym błędem. Oto rzeczy, które zrobiłem dla omniauth-facebook:

Gemfile zawiera:

gem "omniauth", "~> 1.1.4"
gem 'omniauth-facebook', '1.4.1'

W modelu użytkownika dodano:

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"}

Kontroler 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

Czy ktoś może w tym pomóc?

questionAnswers(6)

yourAnswerToTheQuestion