【发布时间】:2016-07-24 18:24:00
【问题描述】:
我使用 Facebook 为我的 WebAPI 服务实现了 OAUTH 登录,我通过以下方法获取令牌:
private static async Task<ExternalLoginData> FromToken(string provider, string accessToken)
{
if (string.IsNullOrEmpty(provider))
return null;
provider = provider.Trim().ToLower();
string verifyTokenEndPoint = "", verifyAppEndpoint = "";
HttpClient client = new HttpClient();
if (provider == ProviderConstants.Facebook)
{
verifyTokenEndPoint = $"https://graph.facebook.com/me?access_token={accessToken}";
verifyAppEndpoint = $"https://graph.facebook.com/app?access_token={accessToken}";
}
else
{
return null;
}
Uri uri = new Uri(verifyTokenEndPoint);
HttpResponseMessage response = await client.GetAsync(uri); <-- exception thrown here
if (response.IsSuccessStatusCode)
{
//not relevant
}
//not relevant
}
在任何配置的本地开发服务器上都不会引发异常。但它在实时服务器上失败并出现以下错误。
知道为什么吗?
Failed when generating token
System.Net.Http.HttpRequestException: An error occurred while sending the request. ---> System.Net.WebException: Unable to connect to the remote server ---> System.Net.Sockets.SocketException: A connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond 1.1.1.1:443
at System.Net.Sockets.Socket.EndConnect(IAsyncResult asyncResult)
at System.Net.ServicePoint.ConnectSocketInternal(Boolean connectFailure, Socket s4, Socket s6, Socket& socket, IPAddress& address, ConnectSocketState state, IAsyncResult asyncResult, Exception& exception)
--- End of inner exception stack trace ---
at System.Net.HttpWebRequest.EndGetResponse(IAsyncResult asyncResult)
at System.Net.Http.HttpClientHandler.GetResponseCallback(IAsyncResult ar)
--- End of inner exception stack trace ---
at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
at System.Runtime.CompilerServices.TaskAwaiter`1.GetResult()
at FishingApp.Controllers.AccountController.<FromToken>d__32.MoveNext() in E:\TeamCity\buildAgent\work\22810208a40a1b66\src\FishingApp\Controllers\AccountController.cs:line 1033
--- End of stack trace from previous location where exception was thrown ---
at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
at System.Runtime.CompilerServices.TaskAwaiter`1.GetResult()
at FishingApp.Controllers.AccountController.<LoginExternalToken>d__30.MoveNext() in E:\TeamCity\buildAgent\work\22810208a40a1b66\src\FishingApp\Controllers\AccountController.cs:line 865
附加信息:看起来我无法连接到 url,因为我收到此错误:Unable to connect to the remote server
【问题讨论】:
标签: facebook asp.net-web-api oauth-2.0