次のリンクで説明および解決された問題があります
...ただし、SilverlightではなくJavaScriptを使用しているため、推奨されるソリューション(クライアントHTTPスタックを使用)を使用できません。
POST /PollingWcfServices/ServiceWcf.svc HTTP/1.1
Accept: */*
Content-Length: 564
Content-Type: application/soap+xml; charset=utf-8
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0
Host: foo
Connection: Keep-Alive
Pragma: no-cache
Cookie: ASP.NET_SessionId=iyr4sf55rm1kypafjdvlhm55
次のポーリングコードが使用されます
request.onreadystatechange = function () {
if (request.readyState == 4) {
if (request.status == 200)
//Process and Poll again
else
//Handle errors
}
request.open("POST", url);
request.setRequestHeader("Content-Type", "application/soap+xml;charset=utf-8");
request.send(httpBody);
残念ながら、セッションはCookieに設定されているため、サーバーは同じセッションサービス呼び出しを順番に処理しようとします。これは、長いポーリングプロセスの大きな問題です。簡単な解決策は、ヘッダーからCookieを削除して、Silverlightクライアントスタックを使用したSilverlightポーリングのように見せることです。
request.setRequestHeaderは、ヘッダー値にのみ追加されます。.sendの先頭にCookieが設定されているように見えるため、これは何の違いもないようです。
Mozillaのみのソリューション。
http://www.michael-noll.com/tutorials/cookie-monster-for-xmlhttprequest/
request.channel.loadFlags |= Ci.nsIRequest.LOAD_ANONYMOUS;
ASP.NET_SessionIDCookieも削除しません。ASPXAUTHcookieは削除されますが。
ASP.NET互換性/セッションが有効な環境で後続のAJAXサービス要求をブロックしないAJAXアクセス可能な長時間実行サービスタスクのソリューションを持っている人はいますか?