在我的网络应用程序中,我添加了一个使用Facebook注册/登录的选项, 它运行正常并且工作正常,我正在使用C#和ASP.NET中的VS2013编码,当我开始调试并按下按钮时,它连接到Facebook并获取所有需要的信息。
当我开始调试并且只在一段时间后按下Facebook按钮时问题就开始了,我已经明白它是某种超时,但我不知道如何解决它。
我的主页上的Page_Load中有这段代码:
System.Net.ServicePointManager.SecurityProtocol = System.Net.SecurityProtocolType.Tls12;
FaceBookConnect.API_Key = "**************";
FaceBookConnect.API_Secret = "**************************";
if (!IsPostBack)
{
if (Request.QueryString["error"] == "access_denied")
{
Page.ClientScript.RegisterStartupScript(this.GetType(), "alert", "alert('User has denied access.')", true);
return;
}
string code = Request.QueryString["code"];
if (!string.IsNullOrEmpty(code))
{
string data = FaceBookConnect.Fetch(code, "me");
FaceBookUser faceBookUser = new JavaScriptSerializer().Deserialize<FaceBookUser>(data);
faceBookUser.PictureUrl = string.Format("https://graph.facebook.com/{0}/picture?width=9999", faceBookUser.Id);
string fname = faceBookUser.Name.Substring(0, faceBookUser.Name.IndexOf(' '));
string lname = faceBookUser.Name.Substring(faceBookUser.Name.IndexOf(' ') + 1);
string email = faceBookUser.Email + "@FB";
string pictureurl = faceBookUser.PictureUrl;
string gender = faceBookUser.Gender;
if (SQLDB.CheckMailExists(email))
{
FormsAuthentication.SetAuthCookie(email, true);
FormsAuthentication.RedirectFromLoginPage(email, true);
}
else
{
SQLDB.AddFBUser(fname, lname, email, gender, pictureurl);
FormsAuthentication.SetAuthCookie(email, true);
FormsAuthentication.RedirectFromLoginPage(email, true);
}
}
}
此代码在“使用Facebook登录”按钮的“点击”代码中:
FaceBookConnect.Authorize("user_photos,email", Request.Url.AbsoluteUri.Split('?')[0]);
我尝试将有关Facebook连接的所有代码从Page_Load移动到Click操作,这样它只会在用户按下按钮时尝试连接,但由于某种原因它无效...
我不确定该怎么做,因为代码是我从网上获取的东西,而不是由我制作的,希望你能告诉我如何只在需要时刷新或连接到Facebook服务器。谢谢!
答案 0 :(得分:0)
如果您怀疑Facebook连接已超时,则应该将其作为任何其他例外处理,并再次重定向到您的登录页面。 这是我的代码:
catch (Exception ex)
{
if (ex is AggregateException && ex.InnerException is Facebook.FacebookOAuthException && usedState != null && HttpContext.Current != null)
{
HttpContext.Current.Response.Redirect("~/FacebookLogin.aspx?logout=true");
}
else
{
throw;
}
}