ページ内の DateTime 値を解析していますが、指定された書式文字列の 1 つと明確に一致しているにもかかわらずASP.NET WebForms
、日付文字列がメソッドによって拒否され続けています。DateTime.TryParseExact()
自宅の開発マシンでは失敗するようですが、本番サーバーでは動作するため、ローカルの日付設定が関係していると考えていますが、IFormatProvider (CultureInfo)
オブジェクトをパラメーターとして指定してもこのエラーが発生します
コードは次のとおりです。
DateTime startDate;
string[] formats = { "dd/MM/yyyy", "dd/M/yyyy", "d/M/yyyy", "d/MM/yyyy",
"dd/MM/yy", "dd/M/yy", "d/M/yy", "d/MM/yy"};
var errStart = row.FindControl("errStartDate"); //my date format error message
if (!DateTime.TryParseExact(txtStartDate.Text, formats, null, DateTimeStyles.None, out startDate))
{
errStart.Visible = true; //we get here even with a string like "20/08/2012"
return false;
}
else
{
errStart.Visible = false;
}
注null FormatProvider
上記では a を指定していますが、このパラメーターに関してCultureInfo
オブジェクトを
指定すると、同じ問題が発生します。(CultureInfo provider = new CultureInfo("en-US"))
私は何が欠けていますか?