铁轨上的红宝石-Devise+OmniAuth Instagram:未找到.身份验证直通



所以我在这个网站上发现了类似的问题,但并没有真正直接的解决方案。

我正在使用omnauth instagram和omnauthfacebook和design,并得到下面的错误(与两个提供商)。

网址:http://localhost:3000/users/auth/callbacks/facebook
错误:Not found. Authentication passthru.

以下是我的callbacks_controller.rbuser.rbroutes.rb的示例——非常感谢任何正确方向的有用提示。如果我应该提供任何其他信息,请告诉我!

callbacks_controller.rb

class Users::Auth::CallbacksController < Devise::OmniauthCallbacksController
  def instagram
      # You need to implement the method below in your model (e.g. app/models/user.rb)
      @user = User.find_for_oauth(request.env["omniauth.auth"], current_users)
      if @user.persisted?
        sign_in_and_redirect @user, :event => :authentication #this will throw if @user is not activated
        set_flash_message(:notice, :success, :kind => "Instagram") if is_navigational_format?
      else
        session["devise.instagram_data"] = request.env["omniauth.auth"]
        redirect_to new_user_registration_url
      end
  end


  def facebook
      # You need to implement the method below in your model (e.g. app/models/user.rb)
      @user = User.find_for_oauth(request.env["omniauth.auth"], current_users)
      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

user.rb

class User < ActiveRecord::Base
  # Include default devise modules. Others available are:
  # :confirmable, :lockable, :timeoutable and :omniauthable
  devise :database_authenticatable, :registerable,
         :recoverable, :rememberable, :trackable, :validatable
  devise  :omniauthable, :omniauth_providers => [:instagram, :facebook]
  def self.find_for_oauth(auth, signed_in_resource = nil)
    # Get the identity and user if they exist
    identity = Identity.find_for_oauth(auth)
    user = identity.user
    if user.nil?
      # Get the existing user from email if the OAuth provider gives us an email
      user = User.where(:email => auth.info.email).first if auth.info.email
        # Create the user if it is a new registration
        if user.nil?
          user = User.new(
            name: auth.extra.raw_info.name,
            #username: auth.info.nickname || auth.uid,
            email: auth.info.email.blank? ? TEMP_EMAIL : auth.info.email,
            password: Devise.friendly_token[0,20]
          )
          user.skip_confirmation!
          user.save!
        end
        # Associate the identity with the user if not already
        if identity.user != user
          identity.user = user
          identity.save!
        end
    end
    user

  end
end

路由.rb
devise_for :users, :controllers => { :omniauth_callbacks => "users/auth/callbacks" }

您在devise.rb中添加了两者吗?

  # devise.rb
  # ...
  # ==> OmniAuth
  # Add a new OmniAuth provider. Check the wiki for more information on setting
  # up on your models and hooks.
  # config.omniauth :github, 'APP_ID', 'APP_SECRET', :scope => 'user,public_repo'
  config.omniauth :facebook, "KEY", "SECRET"
  config.omniauth :instagram, "KEY", "SECRET"

配置策略后,您需要使您的模型(例如app/models/user.rb)具有omniauthable:

design:omniauthable,:omniauth_providers=>[:facebook,:instagram]

最新更新