7

我有问题HttpClient,我一直在HttpRequestException occurred in mscorlib.dll。我已经从 SVN 下载了以前的工作版本,并且一直收到相同的异常。

为什么我会突然得到这个异常,即使我运行的代码已经运行了好几个星期?

现在我正在尝试使用这个简单的代码进行调试,但是无论我做什么都会遇到同样的异常

HttpClient client = new HttpClient();
client.DefaultRequestHeaders.Accept
    .Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue(
              "application/json"));
HttpResponseMessage response
    = await client.GetAsync("http://api.themoviedb.org/3/movie/550?api_key=x");
return await response.Content.ReadAsStringAsync();

我的 innerException 如下:

The remote name could not be resolved: 
    api.themoviedb.org System.Exception System.Net.WebException

我尝试的每个网址都得到相同的结果,它们都在我的浏览器中工作。这是异常和堆栈跟踪:

res "System.Net.Http.HttpRequestException: An error occurred while sending the request. 
---> System.Net.WebException: The remote name could not be resolved: 'api.themoviedb.org'
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.HandleNonSuccessAndDebuggerNotificat‌​ion(Task task)
4

1 回答 1

9

这是您网络上的 DNS 问题。您的工作站(或出现错误的服务器)无法解析 DNS 名称“api.themoviedb.org”。这个 DNS 名称可以很好地从我的计算机和其他在线网络解析。

请咨询您的本地网络管理员。

更新

因此,您的机器可以解析名称,但 HttpClient 不能。让我们看看我们是否可以解决这个问题。我假设这是一个桌面应用程序,而不是一个网站。如果我错了,请告诉我——还有一些额外的注意事项。

您将必须按照本指南启用网络跟踪:如何:配置网络跟踪。您希望按照该链接中的指定配置您的 App.config 文件。简而言之,您应该在配置文件中添加如下内容:

<configuration>
    <system.diagnostics>
        <sources>
            <source name="System.Net" tracemode="includehex" maxdatasize="1024">
                <listeners>
                    <add name="System.Net"/>
                </listeners>
            </source>
        </sources>
        <switches>
            <add name="System.Net" value="Verbose"/>
        </switches>
        <sharedListeners>
            <add name="System.Net"
                type="System.Diagnostics.TextWriterTraceListener"
                initializeData="network.log" />
        </sharedListeners>
        <trace autoflush="true"/>
    </system.diagnostics>
</configuration>

该值network.log应根据您的需要进行更改。继续执行此操作,然后查看输出文件。

现在,诀窍是使用该文件来找出问题所在。有关如何解释该文件的提示,请参阅解释网络跟踪,尽管信息很少。我们正在寻找的是无法解析 DNS 的原因。因此,在该文件中搜索“api.themoviedb.org”。如果您愿意,请使用结果更新问题,我会看看是否可以从那里帮助您。

于 2013-02-28T19:36:02.663 回答