主要问题:我应该如何通过 C# SDK 为 60 天访问 token 延长 2 小时访问 token ?您能否仅提供代码已被交易为 2 小时访问 token 的部分的示例?
背景:我一直在这里环顾四周并尝试各种解决方案,但还没有找到适合我的解决方案。我可以成功进行/me 调用并获取有关当前用户的信息,但是当我尝试扩展访问 token 时它失败了。
这个应用程序的目标是允许用户在一段时间内设置帖子并在事后监控喜欢和评论。显然,我们需要 60 天 token 。
当您可以请求永久 token 时,在其他人完成了 90% 的工作之后,我接管了这个项目。我的工作是修复它,以便我们可以使用 60 天 token 。我可能会问非常愚蠢的后续问题。做好准备!
当前流程:用户设置他的帖子,点击一个按钮,我们提示他们通过 javascript sdk 验证我们的应用程序/登录到 facebook。他们登录后,我们在 javascript 中处理其他不相关的事情,然后将其 AJAX 到 C# 以将一些信息保存到我们的数据库(包括 token )并发布。一切顺利,我在 javascript 中获得访问 token 就好了,我可以使用该 2 小时 token 来获取有关登录用户的信息,但是当我尝试扩展时,我得到两个错误之一,我将在下面提到导致它们的代码。
我试过的:
在职的:
我相信我在这里的另一篇文章中找到了这个。
var fbClient = new FacebookClient(accessToken);
Dictionary<string, object> parameters = new Dictionary<string, object>();
parameters.Add("client_id", appId);
parameters.Add("redirect_uri", redirectURI);
parameters.Add("client_secret", appSecret);
parameters.Add("code", accessToken);
var result = fbClient.Get("/me", parameters);
不工作:
这来自不同的地方,包括这里和 sdk 文档。我见过有人包含重定向 url,并说它需要与您最初获得访问 token 时的那个相匹配,但我们在 javascript 中做到了这一点,并且没有使用重定向 url。
字典参数2 = new Dictionary();
parameters2.Add("client_id", appId);
//parameters2.Add("redirect_uri", redirectURI);
parameters2.Add("client_secret", appSecret);
//parameters2.Add("code", accessToken);
parameters2.Add("grant_type", "fb_exchange_token");
parameters2.Add("fb_exchange_token", accessToken);
var result2 = fbClient.Get("/oauth/access_token", parameters2);
错误:{Newtonsoft.Json.JsonReaderException:解析值时遇到意外字符:a。第 1 行,位置 1。
错误 2:如果我注释掉 grant_type 和 fb_exchange_token 并取消注释代码和重定向程序,我会得到与下一个方法相同的错误...
不工作:
这是我从另一篇文章中抓取的复制/粘贴重命名以匹配我的变量。
Unable to get long lived expiration token
dynamic result3 = new ExpandoObject();
try
{
dynamic parameters3 = new ExpandoObject();
parameters3.grant_type = "fb_exchange_token";
parameters3.fb_exchange_token = accessToken;
parameters3.client_id = appId;
parameters3.client_secret = appSecret;
result3 = fbClient.Get("oauth/access_token", parameters);
}
catch (FacebookOAuthException err)
{
result3.error = "Error";
result3.message = err.Message;
}
catch (Exception err)
{
result3.error = "Error";
result3.message = err.Message;
}
错误:{(OAuthException) (OAuthException) 验证码格式无效。}
最佳答案
在作为回调的处理程序文件中使用以下代码与 Facebook.NET 和 Json.NET。
public void ProcessRequest (HttpContext context)
{
if (context.Request.Params.Get("error_reason") == "user_denied")
{
context.Response.Write("Access Denied");
}
else if (context.Request.Params.Get("code") != null && context.Request.Params.Get("code") != "")
{
string shorttoken = HttpUtility.ParseQueryString(HttpUtil.GetHtmlPage("https://graph.facebook.com/oauth/access_token?client_id=" + APP_ID + "&redirect_uri=http://huadianz.me/mvp/auth/FacebookOAuth.ashx&client_secret=" + APP_SECRET + "&code=" + context.Request.Params.Get("code")))["access_token"];
string longtoken = HttpUtility.ParseQueryString(HttpUtil.GetHtmlPage("https://graph.facebook.com/oauth/access_token?client_id=" + APP_ID + "&client_secret=" + APP_SECRET + "&grant_type=fb_exchange_token&fb_exchange_token=" + shorttoken))["access_token"];
Facebook.FacebookClient fc = new Facebook.FacebookClient(longtoken);
dynamic result = fc.Get("me");
context.Response.Redirect("/");
//Store Token here
}
}
我的实用程序文件在这里:
public static class HttpUtil
{
public static string GetHtmlPage(string strURL)
{
String strResult;
WebResponse objResponse;
WebRequest objRequest = HttpWebRequest.Create(strURL);
objResponse = objRequest.GetResponse();
using (StreamReader sr = new StreamReader(objResponse.GetResponseStream()))
{
strResult = sr.ReadToEnd();
sr.Close();
}
return strResult;
}
}
关于C# Facebook SDK 将访问 token 延长至 60 天,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/12101445/