使用java编程的时候,经常要验证一个日期的正确性,在网上看到一个十分简易但不是很完善的方法,挺有意思的,代码如下:
思路很简单,先把你输入的字符串格式化为日期,在这一过程中,他会把非法的日期向后顺延(如1月32号顺延为2月1号)。之后再把这个日期格式化为字符串。将这2个字符串比较,若相等,则日期合法,反之日期不合法。
为什么说这个方法不完善呢?在于输入的日期格式。由于在函数中使用的模式为 "yyyy-M-d",因此输入的日期不能带多于的0,比如2004-01-22就不行,因为再将日期格式化为字符串时,结果是2004-1-22,根据算法,判定这2个日期不相等(但实际上是相等的)。当然,如果你输入的日期都是补零的(如2003-01-03),那么只需将函数中的模式换为 "yyyy-MM-dd"即可。但是如果输入比较混乱,即有补零的,也有不补零的,那就不行了,程序还要写的更复杂些。
public static boolean validateDate(String date) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-M-d");
try {
Date d = sdf.parse(date);
String s = sdf.format(d);
return date.compareTo(s)==0;
} catch (ParseException e) {
// TODO Auto-generated catch block
return false;
}
}
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-M-d");
try {
Date d = sdf.parse(date);
String s = sdf.format(d);
return date.compareTo(s)==0;
} catch (ParseException e) {
// TODO Auto-generated catch block
return false;
}
}
为什么说这个方法不完善呢?在于输入的日期格式。由于在函数中使用的模式为 "yyyy-M-d",因此输入的日期不能带多于的0,比如2004-01-22就不行,因为再将日期格式化为字符串时,结果是2004-1-22,根据算法,判定这2个日期不相等(但实际上是相等的)。当然,如果你输入的日期都是补零的(如2003-01-03),那么只需将函数中的模式换为 "yyyy-MM-dd"即可。但是如果输入比较混乱,即有补零的,也有不补零的,那就不行了,程序还要写的更复杂些。