我按照这里的步骤操作,在合并帐户时遇到了一些问题
根据说明,我将以下方法添加到我的应用程序控制器中
def after_sign_in_path_for(resource)
# Merge data from Facebook with her current account
if session["facebook_data"] && current_user.facebook_uid.nil?
current_user.facebook_uid = session["facebook_data"]["uid"]
current_user.save(:validate => false)
end
# Countermeasure against session fixation
session.keys.grep(/^facebook./).each { |k| session.delete(k) }
super
end
但是,我在应用程序控制器中得到一个空会话["facebook_data"],即使我在调用此方法的回调应用程序/控制器/用户/omniauth_callbacks_controller.rb 中看到正确的会话值:
class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
def facebook
user = User.find_for_facebook_oauth(env["omniauth.auth"], current_user)
if user && user.persisted?
flash[:notice] = I18n.t "devise.omniauth_callbacks.success", :kind => "Facebook"
sign_in_and_redirect user, :event => :authentication
else
session["facebook_data"] = env["omniauth.auth"]
redirect_to new_user_session_url # this redirect invokes the after_sign_in_path_for method in ApplicationController
end
end
end
我在这里错过了什么?
在众多原因中,有两个原因值得检查:
1) ApplicationController
中的session["facebook_data"]
在omniauth_callbacks_controller.rb
中设置之前被调用。
解决方案:检查两个控制器的调用是否正确同步,即
- 应该先
omniauth_callbacks_controller.rb
,然后再ApplicationController
.
2) session["facebook_data"]
的值在 omniauth_callbacks_controller.rb
中设置后重置为 null。
解决方案:跟踪在 omniauth_callbacks_controller.rb
中设置的session["facebook_data"]
值之后的调用,直到调用 session["facebook_data"]
in ApplicationController
。