我按照步骤here操作,在合并帐户时遇到了一些问题
根据这些说明,我在ApplicationController中添加了以下方法
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然而,尽管我在调用此方法的回调app/controllers/users/omniauth_callbacks_controller.rb中看到了正确的会话值,但我在ApplicationController中得到了一个空会话“facebook_data”:
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这里我漏掉了什么?
发布于 2013-01-25 17:21:52
在许多原因中,有两个原因值得一查:
1)在ApplicationController中的session["facebook_data"]在omniauth_callbacks_controller.rb中设置之前正在被调用。
解决方案:检查两个控制器的调用是否正确同步,即
首先应该是ApplicationController.,然后是
omniauth_callbacks_controller.rb2) session["facebook_data"]在中设置后,其值被重置为omniauth_callbacks_controller.rb null。
解决方案:跟踪omniauth_callbacks_controller.rb中设置的session["facebook_data"]值之后的调用,直到ApplicationController中对session["facebook_data"]的调用。
https://stackoverflow.com/questions/14518230
复制相似问题