0

我正在开发一个 Facebook 应用程序(使用 ASP.NET C# 和 Nathan Totten 的 Facebook C# SDK)并尝试访问扩展权限。我在 localhost 上尝试过(使用 facebook 中的现有应用程序),每个人都可以工作。但是当我尝试直接在 facebook 中使用它时,我得到一个空白页面(我仍然在 facebook 上连接)。

这是我的代码:

页面/aspx:

protected void btn_ask_question_Click(object sender, EventArgs e)
    {
        if (ControllerAccess.testUserConnected())
        {
            if (txt_ask_question.InnerText != "")
            {
                Dictionary<string, object> action = new Dictionary<string,object>();
                action.Add("action", "askQuestion");
                action.Add("message", txt_ask_question.InnerText);
                action.Add("idTheme", ddl_choose_question_category.SelectedValue);
                HttpContext.Current.Session["ActionToDo"] = action;
                String s = Controller.GetExtendedPermission2(this, ControllerAccess.getScopeByAction("askQuestion"));
                try{
                    Response.Redirect(s, false);
                } catch(Exception ex)
                {
                }
            }
        }
    }

在我的 Page_Load() 中:

if (HttpContext.Current.Session["ActionToDo"] != null)
            {
                Dictionary<string, object> action = HttpContext.Current.Session["ActionToDo"] as Dictionary<string, object>;
                String s = action["action"].ToString();
                switch (s)
                {
                    case "askQuestion":
                        Guid idTheme;
                        Boolean themeExists =  Guid.TryParse(action["idTheme"].ToString(), out idTheme);
                        if(themeExists)
                        {
                            askQuestion(action["message"].ToString(), idTheme);
                            lbl_errors.Text = "Votre question a bien été posée";
                        }
                        break;
                    default:
                        break;
                }
                HttpContext.Current.Session["ActionToDo"] = null;
            }

在 Control.cs 中:

    public static string GetCustomOAuthDialogParameters(string AppID, string RedirectURI, string Scope, string State)
    {
        string CustomParameters = "?client_id=" + AppID + "&redirect_uri=" + RedirectURI + "&scope=" + Scope + "&state=" + State;
        return CustomParameters;
    }

    public static void GetExtendedPermission(Page page, String scope)
    {

        ecritureFichier("GetExtendedPermission");
        Label lbl_errors = page.Form.FindControl("lbl_errors") as Label;
        string OAuthDialogAbsoluteURL = "";
        try
        {
            string OAuthDialogURL = "https://www.facebook.com/dialog/oauth";
            string PageLocation = GetCurrentPageFacebookPublishedPath(page.Request); //The redirect page (eg: https://apps.facebook.com/democsharpsdk/TestsExtendedPermission.aspx)
            string UniqueReferenceCode = Guid.NewGuid().ToString();

            OAuthDialogAbsoluteURL = OAuthDialogURL + GetCustomOAuthDialogParameters(AppID, PageLocation, scope, UniqueReferenceCode);
            page.Response.Redirect(OAuthDialogAbsoluteURL, false);
        }
        catch (Exception exp)
        {
            lbl_errors.Text += "Erreur Catchée via ASP.NET : " + exp.Message;
        }
    }

当我使用这一行时出现空白页: page.Response.Redirect(OAuthDialogAbsoluteURL, false);

但是我记录了所有步骤,并且我的 OAuthDialogAbsoluteURL 是正确的:

https://www.facebook.com/dialog/oauth?client_id=XXXXXXXXXXXXXXXXX&redirect_uri=https://apps.facebook.com/name_of_my_app&scope=email&state=0443030f-dddd-4fe6-9d6c-9454409d01b3

当我手动将其输入地址栏中时,一切正常。

您对本地版本和已发布版本之间的区别或重定向不起作用的原因有任何想法吗?也许facebook会阻止一些请求?

谢谢。

4

2 回答 2

0

如果您想使用该应用程序测试不同的环境,请确保您的设置指向托管版本。出于安全原因,Facebook 不允许您授权来自未连接到您的应用程序的站点的用户。

通常,您会看到诸如“URL 不属于应用程序”之类的错误或类似的错误。

于 2012-06-14T14:26:41.363 回答
0

我终于使用 Chrome Debugger 解决了我的问题。错误是:

Refused to display document because display forbidden by X-Frame-Options

我使用 Javascript 来修复它,并且我的重定向是这样的:

Response.Write("<script>");
Response.Write("window.open('"+redirect+"','_top')");
Response.Write("</script>");

希望它会帮助一些人。

于 2012-06-19T08:22:19.727 回答