在使用ASP.Net Forms身份验证时,我遇到了.ASPXAUTH cookie.我有几个问题:
主要问题:我如何通过C#SDK扩展60天访问令牌的2小时访问令牌?您是否可以提供代码已经交换2小时访问令牌的那个部分的样本?
背景:我一直在这里寻找并尝试各种解决方案,但还没有找到适合我的方案.我可以成功地进行/我调用并获取有关当前用户的信息,但是当我尝试扩展访问令牌时它失败了.
此应用程序的目标是允许用户设置帖子并在事件发生后监视喜欢和评论一段时间.显然,我们需要60天令牌.
当你可以申请永久令牌时,其他人做了90%的工作后,我正在接受这个项目.我的工作是修复它,以便我们可以使用60天令牌.我可能会问非常愚蠢的后续问题.做好准备!
当前流程:用户设置他的帖子,点击一个按钮,我们提示他们通过javascript sdk授权我们的app /登录facebook.在他们登录后,我们在javascript中处理其他不相关的东西,然后将其AJAX转移到C#以将一些信息保存到我们的数据库(包括令牌)并发布帖子.一切都很好,我在javascript中获得访问令牌就好了,我可以使用该2小时令牌来获取登录用户的信息,但是当我尝试扩展时,我得到两个错误之一,我将在下面提到导致它们的代码.
我尝试过的:
工作:我相信我在这里发现了另一篇文章.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);
Run Code Online (Sandbox Code Playgroud)
不工作:这来自各个地方,包括这里和sdk文档.我见过人们包括重定向网址,并说当你最初获得accessstoken时它需要匹配一个但是我们在javascript中做了这个并且没有使用重定向网址.Dictionary parameters2 = 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);
Run Code Online (Sandbox Code Playgroud)
错误:{Newtonsoft.Json.JsonReaderException:解析值时遇到意外的字符:a.第1行,第1位.错误2:如果我注释掉grant_type和fb_exchange_token并取消注释代码和redirecturi,我会得到与下一个方法相同的错误...
不工作:我从另一个帖子中抓取这里复制/粘贴重命名以匹配我的vars. 无法获得长期到期令牌
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 …Run Code Online (Sandbox Code Playgroud) javascript c# facebook-javascript-sdk facebook-c#-sdk facebook-access-token