他の Web サービスを呼び出す ASP.NET アプリで Cookie を管理しようとしています。特定の環境でしか再現できないエラーが発生しています。私の質問は次のとおりです。
- 本番環境と開発環境の違いは、この問題を引き起こすのに十分ですか?
- 本番環境と開発環境の違いはどうすればわかりますか?
- この問題を回避するにはどうすればよいですか?
以下は、問題を再現するために使用する詳細です。私が見るエラーは次のとおりです。
Unhandled Exception: System.Net.CookieException:
An error occurred when parsing the Cookie header for Uri 'http://example.com/'.
---> System.Net.CookieException: Cookie format error.
at System.Net.CookieContainer.CookieCutter(Uri uri, String headerName,
String setCookieHeader, Boolean isThrow)
--- End of inner exception stack trace ---
at System.Net.CookieContainer.CookieCutter(Uri uri, String headerName,
String setCookieHeader, Boolean isThrow)
at System.Net.CookieContainer.SetCookies(Uri uri, String cookieHeader)
at Program.Main() in c:\Sample\Program.cs:line 21
問題を再現するコンソールアプリを作成しました(以下の関連部分)。https://compilr.com/adutton/cookiecutterexample/main.csの完全なコード
string[] cultures = new[] { "en-US", "es-MX" };
const string cookieHeader = ".ASPXAUTH=SECURITYINFO; domain=.example.com; "
+ "expires=Mon, 06-Mar-2023 18:36:33 GMT; path=/; HttpOnly";
foreach (string culture in cultures)
{
Console.WriteLine("CookieCutting with culture: " + culture);
Thread.CurrentThread.CurrentCulture = new CultureInfo(culture);
Thread.CurrentThread.CurrentUICulture = new CultureInfo(culture);
CookieContainer ctr = new CookieContainer();
// The following line throws an exception
ctr.SetCookies(new Uri("http://example.com/"), cookieHeader);
}
このコードは私の開発マシン (Windows 7、x64、.NET 4.5.50709) では機能しますが、コードがカルチャの例外をスローする実稼働環境 (Windows Server 2008 R2 Enterprise、x64、.NET 4.0.30319) では機能しませんes-MX
。
Cookie ヘッダーから日付を削除すると、例外がなくなり、Cookie パーサーのローカリゼーションの問題であると思われます。おそらく、これは .NET 4.0 -> 4.5 で修正されたのでしょうか?