通过C#消费OAuth2 RESTful服务时出现授权错误500

时间:2015-04-17 18:03:08

标签: c# rest oauth oauth-2.0 restful-authentication

我目前的工作是使用OAuth2来使用RESTful API。目前我研究了如何获取访问令牌,并且在我使用chrome扩展Rest Console时工作正常,但是当我尝试从我的应用程序执行此操作时,我总是收到错误,即我发送了无效的OAuth请求。您可以在下面看到我尝试使用API​​的三种方法,但没有成功。页面总是返回错误500.如果我错过了一些重要的事情,我们将不胜感激。

    var auth = "Bearer " + item.access_token;


    /* First Attempt */
    var client = new RestClient("http://<link>");
    var request = new RestRequest("sample", Method.GET);
    request.AddHeader("Authorization", auth);
    request.AddHeader("Content-Type", "application/json;charset=UTF-8");
    request.AddHeader("Pragma", "no-cache");
    request.AddHeader("User-Agent", "User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.118 Safari/537.36");
    request.AddHeader("Accept", "application/json");
    request.RequestFormat = DataFormat.Json;
    var response = client.Execute(request);
    var content = response.Content;





    /* Second Attempt */
    string sURL = "http://<link>/sample";

    string result = "";

    using (WebClient client = new WebClient())
    {
        client.Headers["Authorization"] = auth;
        client.Headers["Content-Type"] = "application/json;charset=UTF-8";
        client.Headers["Pragma"] = "no-cache";
        client.Headers["User-Agent"] = "User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.118 Safari/537.36";
        client.Headers["Accept"] = "application/json";

        byte[] byteArray = Encoding.UTF8.GetBytes(parameters);

        var result1 = client.DownloadString(sURL);
    }


    /* Third Attempt */
    var request = (HttpWebRequest)WebRequest.Create(sURL);
    request.Method = "GET";
    request.ContentType = "application/json;charset=UTF-8";
    request.Accept = "application/json";
    request.Headers["Authorization"] = auth;
    request.UserAgent = "User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.118 Safari/537.36";
    string content;
    HttpStatusCode statusCode;
    using (var response = request.GetResponse())
    using (var stream = response.GetResponseStream())
    {
        var contentType = response.ContentType;
        Encoding encoding = null;
        if (contentType != null)
        {
            var match = Regex.Match(contentType, @"(?<=charset\=).*");
            if (match.Success)
                encoding = Encoding.GetEncoding(match.ToString());
        }

        encoding = encoding ?? Encoding.UTF8;

        statusCode = ((HttpWebResponse)response).StatusCode;
        using (var reader = new StreamReader(stream, encoding))
            content = reader.ReadToEnd();
    }

-------- -------- EDIT

首次尝试时,我还尝试将身份验证添加到客户端变量client.Authenticator = Authenticate;,其中OAuth2AuthorizationRequestHeaderAuthenticator Authenticate = new OAuth2AuthorizationRequestHeaderAuthenticator(item.access_token, item.token_type);

1 个答案:

答案 0 :(得分:2)

代码似乎正确。您尝试的失败尝试表明问题在于令牌,而不是代码。持有人令牌有到期时间。所以semms就像你的令牌在你第一次使用chrome REST Console扩展和你编写代码之间的时间到了。但这里奇怪的情况是你得到的500错误代码。当令牌过期或不存在时,401是标准响应。 500错误代码始终意味着服务器错误。