HttpwebRequest - 来自HRESULT的异常:0x800710DD

时间:2015-11-06 16:59:49

标签: c# uwp

我尝试向服务器发送cookie。但是当它发生时,它抛出了一个我无法追踪的奇怪异常:

Message "The operation identifier is not valid. (Exception from HRESULT: 0x800710DD)"   string
StackTrace  "   at Windows.Web.Http.Filters.HttpBaseProtocolFilter.SendRequestAsync(HttpRequestMessage request)\r\n   at System.Net.Http.HttpHandlerToFilter.<SendAsync>d__1.MoveNext()"    string

抛出异常的行:

Request.BeginGetResponse( new AsyncCallback( GetResponseCallback ) , Request );

在开始之前,我一直没想到这是一个cookie问题,直到我注释掉这一行:

WCRequest.CookieContainer = WBackgroundTransfer.Cookies;

如果注释上面的行,则异常消失。所以我尝试了另一种方法:

CookieContainer CC = new CookieContainer();
CC.Add( new Cookie( "aa", "bb" ) );
WCRequest.CookieContainer = CC;

上述行不会引发任何异常。然后我继续修改我的代码:

CookieContainer CC = new CookieContainer();
foreach( Cookie C in WBackgroundTransfer.Cookies.GetCookies( ReqURI ) )
{
    CC.Add( new Cookie( C.Name, C.Value, C.Path, C.Domain ) );
}
WCRequest.CookieContainer = CC;

异常又回来了!

然后我尝试再次修改代码:

WCRequest.Headers[ HttpRequestHeader.Cookie ] = WBackgroundTransfer.Cookies.GetCookieHeader( ReqUri );

异常仍然存在。我将代码修改为:

WCRequest.Headers[ HttpRequestHeader.Cookie ] = "ab=cd";

这有效!

所以我认为一些cookie导致了这个问题。我继续比较服务器响应。

我发送给服务器的确切cookie是:

PHPSESSID=j0g94fgvum0flhlop5868gjkklc5bh1v

当我将上述cookie发送到服务器时,响应是:

HTTP/1.1 200 OK
Date: Fri, 06 Nov 2015 16:51:13 GMT
Content-Type: application/xml
Transfer-Encoding: chunked
Connection: keep-alive
Set-Cookie: __cfduid=dd4e3badd19f3f67e86fe1431b7fe895a1446828673; expires=Sat, 05-Nov-16 16:51:13 GMT; path=/; domain=.example.com; HttpOnly
Set-Cookie: PHPSESSID=j0g94fgvum0flhlop5868gjkklc5bh1v; path=/; HttpOnly
Vary: Accept-Encoding
Server: nginx
CF-RAY: 24124d464d493439-HKG

当我发送一个随机的,不相关的cookie,或者不向服务器提供任何cookie时:

HTTP/1.1 200 OK
Date: Fri, 06 Nov 2015 16:53:24 GMT
Content-Type: application/xml
Transfer-Encoding: chunked
Connection: keep-alive
Set-Cookie: __cfduid=d0a29df98a2984c4f5c4b2ddbc900fde01446828804; expires=Sat, 05-Nov-16 16:53:24 GMT; path=/; domain=.example.com; HttpOnly
Vary: Accept-Encoding
Server: nginx
CF-RAY: 2412507ad4c6330d-HKG

这两行请求的唯一区别是这一行:

Set-Cookie: PHPSESSID=j0g94fgvum0flhlop5868gjkklc5bh1v; path=/; HttpOnly

告诉我设置我发送给它的cookie。

这非常令人沮丧。这是API错误吗?或者我错过了什么?我无法修改服务器行为,因此我不能100%确定这是原因。

有什么想法吗?

更新:这只发生在x64平台上!我开始认为这可能是一个heisengbug ......

Update2:不,这种情况发生在所有平台上。我只是没有彻底测试它:(

更新3:这是没有希望的。我将尝试切换到套接字以查看它是否有帮助

2 个答案:

答案 0 :(得分:2)

您是否检查过此解决方案:https://stackoverflow.com/a/33863365

您可以删除不需要的额外Cookie。

HttpBaseProtocolFilter filter = new HttpBaseProtocolFilter();
HttpCookieManager cookieManager = filter.CookieManager;
foreach (HttpCookie cookie in cookieManager.GetCookies(uri))
{
    cookieManager.DeleteCookie();
}

答案 1 :(得分:1)

如果有人遇到这个问题。对我来说,通过清除项目中生成的库可以神奇地解决它。即删除以下目录:

obj/*
bin/*
Debug/*
ARM/*
Release/*
x64/*

更新1:我刚注意到HttpWebRequest是在内部设置Cookies自动发送它们。它应该这样做吗?