Facebook iframe应用程序在用户授权后被重定向到canvas外

在用户授权应用程序后,我的Facebook应用程序被重定向到canvasURL(http:// my-domain / app)。 步骤顺序如下所述:

1)新用户在canvas中打开应用程序,并通过Javascript重定向重定向到oauth权限对话框

2)一旦用户授权了应用程序,就会调用应用程序的redirect_uri并获取我在会话中保存的访问令牌

3)我还获取授权用户的用户ID并将其保存到会话中

4)当我将其重定向到canvasURL时,它会移出facebookcanvas

5)如果我尝试将其重定向到canvas页面(http://apps.facebook.com/app_name),它会陷入无限循环,因为会话值被清除并且过程重复 – 我不知道为什么。

这是一个rails 3应用程序,我正在使用考拉gem。 代码如下所示:

def index if (session[:access_token].blank?) session[:oauth] = Koala::Facebook::OAuth.new(APP_ID, APP_SECRET, oauth_redirect_url) end @app_id = APP_ID end def redirect session[:access_token] = session[:oauth].get_access_token(params[:code]) if params[:code] if session[:access_token].blank? flash[:error] = "You didn't authorize the application. Please authorize the application to throw a firecracker on your friend's wall!" redirect_to :action => "authorize_app" and return else session[:fb_user_id] = Koala::Facebook::API.new(session[:access_token]).get_object("me")["id"] end redirect_to :action => "index" end 

我浪费了将近一天的时间来试图修复它,并寻找解决方案,但现在还没有。

步骤1,步骤2,步骤3都可以

第4步:当用户授权您的应用时,它将被重定向到canvas url上的yourapp.com(canvas url),您将执行以下操作:

  

第5步:当您的canvas页面被调用时,您将获得signed_request然后使用您的fb api,您将解析它。

Interesting Posts