我们需要有关使用asp.net asp的正则表达式的帮助:RegularExpressionValidator以MMddyy格式验证日期。我们面临的问题是闰年。问题是,是否可以通过正则表达式验证它只接受有效的闰年日期,例如02/29/2008是有效日期,但02/29/2010不是有效日期。
任何适用于“asp:RegularExpressionValidator”的正则表达式?
答案 0 :(得分:15)
好的,你问了一个正则表达式。这里是。我认为为什么用正则表达式验证日期不是一个好主意:
首先,详细的评论版本至少可以理解这种野兽:
^ # start of string
(?: # either match...
(?:
(?: # 31st day of all allowed months
(?:(?:0?[13578]|1[02])/31)
| # or
(?:(?:0?[13-9]|1[0-2])/(?:29|30))
) # 29th/30th day of any month except February
/ # plus any year since 1600
(?:1[6-9]|[2-9]\d)
\d{2}
)
| # or
(?: # match Feb 29th
0?2/29/
(?: # in all leap years since 1600
(?:
(?: # century
1[6-9]|[2-9]\d
)
(?: # two-digit years divisible by four, not ending in 00
0[48]
|
[2468][048]
|
[13579][26]
)
|
(?: # all the leap years ending in 00
(?:16|[2468][048]|[3579][26])
00
)
)
)
)
| # or
(?: # (for any month)
(?:0?[1-9])
|
(?:1[0-2])
)
/
(?: # match the 1st-28th day
0?[1-9]|1\d|2[0-8]
)
/
(?:
(?:1[6-9]|[2-9]\d)\d{2}
)
)$
或者,如果您不能在ASP.NET验证器中使用详细的正则表达式:
^(?:^(?:(?:(?:(?:(?:0?[13578]|1[02])/31)|(?:(?:0?[13-9]|1[0-2])/(?:29|30)))/(?:1[6-9]|[2-9]\d)\d{2})|(?:0?2/29/(?:(?:(?:1[6-9]|[2-9]\d)(?:0[48]|[2468][048]|[13579][26])|(?:(?:16|[2468][048]|[3579][26])00))))|(?:(?:0?[1-9])|(?:1[0-2]))/(?:0?[1-9]|1\d|2[0-8])/(?:(?:1[6-9]|[2-9]\d)\d{2}))$)$
这些允许但不要求在一位数月/天内使用前导零。如果您不想这样做,请将0?
的所有实例替换为0
。
答案 1 :(得分:2)
如果服务器端不是选项,则必须使用JavaScript。尝试发布的代码并解释here。它确定02/29/2010无效且02/29/2008有效。必要时使用CustomValidator调用JavaScript函数。
答案 2 :(得分:1)
由于您需要逻辑来验证闰年,请考虑使用CustomValidator
。我把它放在一起相对较快,但希望你能得到这个想法。
protected void dateFormatValidator_ServerValidate(object source, ServerValidateEventArgs args)
{
if (args.Value.Length == 6)
{
var month = args.Value.Substring(0, 2);
var day = args.Value.Substring(2, 2);
var year = args.Value.Substring(4, 2);
DateTime dummyValue;
args.IsValid = DateTime.TryParse(month + "/" + day + "/" + year, out dummyValue);
}
else
{
args.IsValid = false;
}
}
答案 3 :(得分:0)
正如bitwise所说,客户端JS是这样做的方式,而不是一个可怕的正则表达式和汤姆的令人难以置信的帖子。我的工作机器上有一个非常整洁的日期验证器,我将在周一发布。
如果你的应用程序出现某种失败的验证问题,你能想象试图解密那个正则表达式的噩梦吗?