WebClient上的InvalidComObjectException

时间:2012-06-29 00:47:07

标签: c# wpf multithreading c#-4.0 webclient

我有以下代码;

System.Threading.Thread thread = new System.Threading.Thread(
    new System.Threading.ThreadStart(
        delegate()
        {
            WebClient wc = new WebClient();
            wc.Credentials = System.Net.CredentialCache.DefaultCredentials;
            var data = wc.DownloadData(address); // exception (sometimes) here
        }
    ));
thread.SetApartmentState(System.Threading.ApartmentState.STA);
thread.Start();

调用是在一个线程中,因为为了简单起见,我已经删除了其他内容。

在我的开发机器上,此代码将在1%的时间内抛出异常,在另一台机器上,代码在第一次调用时起作用,然后在任何连续调用时抛出异常。

例外情况如下;

System.Net.WebException: The request was aborted: The request was canceled. ---> System.Runtime.InteropServices.InvalidComObjectException: COM object that has been separated from its underlying RCW cannot be used.
   at System.StubHelpers.StubHelpers.GetCOMIPFromRCW(Object objSrc, IntPtr pCPCMD, Boolean& pfNeedsRelease)
   at MS.Win32.UnsafeNativeMethods.IInternetSecurityManager.MapUrlToZone(String pwszUrl, Int32& pdwZone, Int32 dwFlags)
   at MS.Internal.AppModel.CustomCredentialPolicy.MapUrlToZone(Uri uri)
   at MS.Internal.AppModel.CustomCredentialPolicy.ShouldSendCredential(Uri challengeUri, WebRequest request, NetworkCredential credential, IAuthenticationModule authenticationModule)
   at System.Net.NtlmClient.DoAuthenticate(String challenge, WebRequest webRequest, ICredentials credentials, Boolean preAuthenticate)
   at System.Net.NtlmClient.Authenticate(String challenge, WebRequest webRequest, ICredentials credentials)
   at System.Net.AuthenticationManager.Authenticate(String challenge, WebRequest request, ICredentials credentials)
   at System.Net.AuthenticationState.AttemptAuthenticate(HttpWebRequest httpWebRequest, ICredentials authInfo)
   at System.Net.HttpWebRequest.CheckResubmitForAuth()
   at System.Net.HttpWebRequest.CheckResubmit(Exception& e)
   at System.Net.HttpWebRequest.DoSubmitRequestProcessing(Exception& exception)
   at System.Net.HttpWebRequest.ProcessResponse()
   at System.Net.HttpWebRequest.SetResponse(CoreResponseData coreResponseData)
   --- End of inner exception stack trace ---
   at System.Net.WebClient.DownloadDataInternal(Uri address, WebRequest& request)
   at System.Net.WebClient.DownloadData(Uri address)
   at System.Net.WebClient.DownloadData(String address)

我已经在SO上看到了关于此异常的其他问题,但是它们似乎特定于实际使用interop(excel或其他)并及早处理它,这只是对WebClient的调用(并且是在每次通话时实例化)

WebClient是否实际访问了一些内部(静态?)互操作,这里有一些垃圾收集问题?

有趣的是,此代码是从应用程序的各个部分调用的(它从报告服务返回报告),但只在特定报告上失败(有时)。我已检查过报告服务器日志,但是当抛出此异常时,不会尝试进行http连接,因此调用在wc.DownloadData()之前和之内都会失败。

有关为何抛出此异常的任何想法?

==编辑==

尝试使用wc.Displose(),但异常仍然发生(仍偶尔发生)。代码由WPF应用程序调用,如果发生异常,则会在每次连续调用时发生,直到重新启动应用程序。

0 个答案:

没有答案