我正在尝试将控制台应用程序授权给使用oAuth 2.0的API。我尝试过DotNetOpenAuth但没有成功。
第一步是获取授权代码,这是我所拥有的,但我找不到授权代码继续执行步骤2(使用预定义授权代码授权,具有用户ID和用户密码)。我使用了文档中的以下授权标头 https://sandbox-connect.spotware.com/draftref/GetStartAccounts.html#accounts?
在响应中,我没有获得任何带有身份验证代码的标头,我该如何解决?
string sAuthUri = "https://sandbox-connect.spotware.com/oauth/v2/auth";
string postData ="access_type=online&approval_prompt=auto&client_id=7_5az7pj935owsss8kgokcco84wc8osk0g0gksow0ow4s4ocwwgc&redirect_uri=http%3A%2F%2Fwww.spotware.com%2F&response_type=code&scope=accounts";
string sTokenUri = "https://sandbox-connect.spotware.com/oauth/v2/token";
var webRequest = (HttpWebRequest)WebRequest.Create(sAuthUri);
webRequest.Method = "POST";
webRequest.ContentType = "application/x-www-form-urlencoded";
try
{
using (Stream s = webRequest.GetRequestStream())
{
using (StreamWriter sw = new StreamWriter(s))
sw.Write(postData.ToString());
}
using (WebResponse webResponse = webRequest.GetResponse())
{
using (var reader = new StreamReader(webResponse.GetResponseStream()))
{
response = reader.ReadToEnd();
}
}
var return = response;
}
catch (Exception ex)
{
}
答案 0 :(得分:0)
使用OAuth2的Auhtorization代码流,代码应该在重定向到redirect_uri的查询字符串中。
我认为问题出在call方法(应该是GET),postData为QueryString,而redirect_uri必须是你系统的url(不是spotware)。应从webResponse的查询字符串中检索授权代码。
我建议您使用DotNetOpenAuth库轻松实现OAuth2请求。