Omniauth Facebook перенаправляет на экран регистрации вместо создания пользователя

Точно следуя инструкции к самоцвету, я все еще сталкиваюсь с некоторыми проблемами. Сначала я нажимаю на ссылку, чтобы зарегистрироваться через Facebook и перенаправить на Facebook. Я нажимаю "ОК" и возвращаюсь на свою страницу регистрации. Новый пользователь не создан. Если я попытаюсь снова щелкнуть ссылку регистрации, она просто обновит страницу с этим в адресной строке. http://localhost:3000/register#_=_, Что я делаю неправильно?

Модель пользователя

devise :database_authenticatable, :registerable,
         :recoverable, :rememberable, :trackable, :validatable, :omniauthable, omniauth_providers: [:facebook]

def self.from_omniauth(auth)
  where(provider: auth.provider, uid: auth.uid).first_or_create do |user|
    user.email = auth.info.email
    user.password = Devise.friendly_token[0,20]
    user.first_name = auth.info.first_name
    user.last_name = auth.info.last_name
  end
end

Контроллер обратного вызова

class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
  def facebook
    # You need to implement the method below in your model (e.g. app/models/user.rb)
    @user = User.from_omniauth(request.env["omniauth.auth"])

    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

Консольный код

Started GET "/auth/facebook/callback?code=AQCh2rckn0dMOKNggTQJEbx_LTMGjNrDdumTu_Ay9Cwr_87A2pro_gOgFtSa866DouLuj4kMLVMMPfR3amp_X6rNSlAwOQ51RXK053vxhtEyJNY8StcqiOVZ6YqpGmfg8Zsz8RIXQr2xRclPmW9j9o8fqg83CoFiH1j-e_YOOuyCaX6xkoVN1eC3kjWSezg_WFm3p6aXu_XYxw1-Jf2j3Ijqt4kR4ySLHfmauj1z9UUcy5HANMIjaRx84NiZHNdJq6fzuAT37y9cXvP5HawonBBA0bG7ejAk5AATBYJj-kTXdCR9673cQ55O4GbAw_LCzzy7_YgHkFR9S038tP68HnXm&state=d013067bc67bd4bff43b6ac77bea69f5b113858cb234452a" for ::1 at 2015-07-12 19:28:55 -0400
I, [2015-07-12T19:28:55.026584 #7266]  INFO -- omniauth: (facebook) Callback phase initiated.
Processing by Users::OmniauthCallbacksController#facebook as HTML
  Parameters: {"code"=>"AQCh2rckn0dMOKNggTQJEbx_LTMGjNrDdumTu_Ay9Cwr_87A2pro_gOgFtSa866DouLuj4kMLVMMPfR3amp_X6rNSlAwOQ51RXK053vxhtEyJNY8StcqiOVZ6YqpGmfg8Zsz8RIXQr2xRclPmW9j9o8fqg83CoFiH1j-e_YOOuyCaX6xkoVN1eC3kjWSezg_WFm3p6aXu_XYxw1-Jf2j3Ijqt4kR4ySLHfmauj1z9UUcy5HANMIjaRx84NiZHNdJq6fzuAT37y9cXvP5HawonBBA0bG7ejAk5AATBYJj-kTXdCR9673cQ55O4GbAw_LCzzy7_YgHkFR9S038tP68HnXm", "state"=>"d013067bc67bd4bff43b6ac77bea69f5b113858cb234452a"}
  User Load (0.1ms)  SELECT  "users".* FROM "users" WHERE "users"."provider" = ? AND "users"."uid" = ?  ORDER BY "users"."id" ASC LIMIT 1  [["provider", "facebook"], ["uid", "836028396465704"]]
   (0.1ms)  begin transaction
   (0.0ms)  rollback transaction
Redirected to http://localhost:3000/register
Completed 302 Found in 59ms (ActiveRecord: 0.2ms)

2 ответа

Решение

Добавьте эту строку в config/initializer /devise.rb

config.omniauth :facebook, "app id", "app secret", scope: 'email', info_fields: 'email'

В новой версии Facebook API есть изменения, представив Graph API v2.4

Меньше полей по умолчанию для повышения производительности. Чтобы повысить производительность подключений к мобильной сети, мы сократили количество полей, которые API возвращает по умолчанию. Теперь вы должны использовать синтаксис? Fields=field1,field2, чтобы объявить все поля, которые должен возвращать API.

Если вы следите за вики-страницей устройства, аутентификация не пройдена. В контроллере tge, если аутентификация не проходит, он перенаправляет на путь регистрации. Точно так же, как сказал Мохамед, но теперь вы должны добавить first_name и last_name к своим полям информации. Итак, в config / initializers / devise.rb напишите этот config.omniauth: facebook, "идентификатор приложения", "секрет приложения", область действия: "электронная почта", поля информации: 'электронная почта, first_name, last_name'

Другие вопросы по тегам