`
chenbj920
  • 浏览: 3699 次
  • 性别: Icon_minigender_1
  • 来自: 广州
最近访客 更多访客>>
社区版块
存档分类
最新评论

数据验证

 
阅读更多
import java.util.Date;

import java.util.List;

public class ValidateUtil {

public static final String DATE_FORMAT_1 = "yyyy/MM/dd";
public static final String DATE_FORMAT_2 = "MM/dd/yyyy";
public static final String DATE_FORMAT_3 = "dd/MM/yyyy";
public static final String DATE_FORMAT_4 = "yyyy/MM/dd hh:mm:ss";
public static final String DATE_FORMAT_5 = "MM/dd/yyyy hh:mm:ss";
public static final String DATE_FORMAT_6 = "dd/MM/yyyy hh:mm:ss";
public static final String TIME_FORMAT_1 = "hh:mm:ss";
public static final String TIME_FORMAT_2 = "hh:mm";

public static boolean isEmail(String email) {
if (email == null || email.length() < 5)
return false;

String regex = "^\\w+([-+.]\\w+)*@\\w+([-.]\\w+)*\\.\\w+([-.]\\w+)*$";
return email.matches(regex);
}

public static boolean isEmpty(String val) {

return val == null || val.trim().length() == 0;
}

public static boolean isEqual(String val1,String val2) {
if(val1 != null){
return val1.equals(val2);
}else if(val2 != null){
return val2.equals(val1);
}else{
return true;
}
}

/**
* Rule: length: >= 8 <= 20 characters, at least one upper case character, and one digit.
*/
public static boolean checkPassword(String password) {
if (password == null || password.length() < 8 || password.length() > 20)
return false;

char [] pwd = password.trim().toCharArray();
        int c = 0;
        for (int i = 0; i < pwd.length; i++) {
            if ((int)pwd[i] >= 48 && (int)pwd[i] <= 57) {
                c++;
                break;
            }
        }
        if(c==0){
            return false;
        }
        c = 0;
        for (int i = 0; i < pwd.length; i++)
        {
            if ((int)pwd[i] >= 65 && (int)pwd[i] <= 90)
            {
                c++;
                break;
            }
        }
        if (c == 0)
        {
            return false;
        }
       
        return true;
}

public static boolean checkPassword(String password,String regex) {
if (password == null || password.length() <= 0)
return false;

return password.matches(regex);
}

public static boolean isAtoZ(String val) {

if (val == null || val.length() <= 0)
return false;

String regex = "^[A-Za-z]+$";
return val.matches(regex);
}

public static boolean isNumber(String val) {
if (val == null || val.length() <= 0)
return false;

String regex = "^-?([1-9]\\d*\\.?\\d*|0\\.?\\d*[1-9]\\d*|0?\\.?0+|0)$";
return val.matches(regex);

}

public static boolean isInteger(String val) { 

if (val == null || val.length() <= 0)
return false;

String regex = "^-?[1-9]\\d*$";
return val.matches(regex);
}

public static boolean isPositiveInteger(String val) {

if (val == null || val.length() <= 0)
return false;

String regex = "^[1-9]\\d*$";
return val.matches(regex);
}

public static boolean isDate(String date) {
if (date == null)
return false;

String regex = "^[0-9]{4}/(((0[13578]|1[02])/(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)/(0[1-9]|[12][0-9]|30))|(02/(0[1-9]|[1][0-9]|2[0-8])))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))/02/29)$";
if(date.matches(regex)){
return true;
}

regex = "^((((0[13578]|1[02])/(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)/(0[1-9]|[12][0-9]|30))|(02/(0[1-9]|[1][0-9]|[2][0-8])))/[0-9]{4})|(02/29/(([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00)))$";
if(date.matches(regex)){
return true;
}

regex = "^((((0[1-9]|[12][0-9]|3[01]))/(0[13578]|1[02])|((0[1-9]|[12][0-9]|30)/(0[469]|11))|((0[1-9]|[1][0-9]|[2][0-8]))/02)/[0-9]{4})|(29/02/(([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00)))$";
if(date.matches(regex)){
return true;
}

regex = "([0-9]{4}/(((0[13578]|1[02])/(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)/(0[1-9]|[12][0-9]|30))|(02/(0[1-9]|[1][0-9]|2[0-8])))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))/02/29)) ([0-1][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$";
if(date.matches(regex)){
return true;
}

regex = "^(((((0[13578]|1[02])/(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)/(0[1-9]|[12][0-9]|30))|(02/(0[1-9]|[1][0-9]|[2][0-8])))/[0-9]{4})|(02/29/(([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00)))) ([0-1][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$";
if(date.matches(regex)){
return true;
}

regex = "^(((((0[1-9]|[12][0-9]|3[01]))/(0[13578]|1[02])|((0[1-9]|[12][0-9]|30)/(0[469]|11))|((0[1-9]|[1][0-9]|[2][0-8]))/02)/[0-9]{4})|(29/02/(([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00)))) ([0-1][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$";
if(date.matches(regex)){
return true;
}

regex = "^([0-1][0-9]|2[0-3]):([0-5][0-9])$";
if(date.matches(regex)){
return true;
}

regex = "^([0-1][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$";
if(date.matches(regex)){
return true;
}

return false;
}

public static boolean isDate(String date, String format) {
String regex = "";
if(DATE_FORMAT_1.equals(format)){
regex = "^[0-9]{4}/(((0[13578]|1[02])/(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)/(0[1-9]|[12][0-9]|30))|(02/(0[1-9]|[1][0-9]|2[0-8])))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))/02/29)$";
}else if(DATE_FORMAT_2.equals(format)){
regex = "^((((0[13578]|1[02])/(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)/(0[1-9]|[12][0-9]|30))|(02/(0[1-9]|[1][0-9]|[2][0-8])))/[0-9]{4})|(02/29/(([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00)))$";
}else if(DATE_FORMAT_3.equals(format)){
regex = "^((((0[1-9]|[12][0-9]|3[01]))/(0[13578]|1[02])|((0[1-9]|[12][0-9]|30)/(0[469]|11))|((0[1-9]|[1][0-9]|[2][0-8]))/02)/[0-9]{4})|(29/02/(([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00)))$";

}else if(DATE_FORMAT_4.equals(format)){
regex = "([0-9]{4}/(((0[13578]|1[02])/(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)/(0[1-9]|[12][0-9]|30))|(02/(0[1-9]|[1][0-9]|2[0-8])))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))/02/29)) ([0-1][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$";
}else if(DATE_FORMAT_5.equals(format)){
regex = "^(((((0[13578]|1[02])/(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)/(0[1-9]|[12][0-9]|30))|(02/(0[1-9]|[1][0-9]|[2][0-8])))/[0-9]{4})|(02/29/(([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00)))) ([0-1][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$";
}else if(DATE_FORMAT_6.equals(format)){
regex = "^(((((0[1-9]|[12][0-9]|3[01]))/(0[13578]|1[02])|((0[1-9]|[12][0-9]|30)/(0[469]|11))|((0[1-9]|[1][0-9]|[2][0-8]))/02)/[0-9]{4})|(29/02/(([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00)))) ([0-1][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$";

}else if(TIME_FORMAT_1.equals(format)){
regex = "^([0-1][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$";
}else if(TIME_FORMAT_2.equals(format)){
regex = "^([0-1][0-9]|2[0-3]):([0-5][0-9])$";
}else{
return false;
}

return date.matches(regex);
}

public static int compareDate(Date date1, Date date2) throws NullPointerException{

if(date1 == null || date2 == null)
throw new NullPointerException();

return date1.compareTo(date2);
}

public static boolean minlength(String str, Integer compareVal) {
if (str == null)
return false;

return str.length() >= compareVal;
}

public static boolean maxlength(String str, Integer compareVal) {

if (str == null)
return false;

return str.length() <= compareVal;
}

public static boolean rangeLength(String str, Integer min, Integer max) {
if (str == null)
return false;

return str.length() >= min && str.length() <= max;
}

public static boolean rangeValue(int val, int min, int max) {

return val >= min && val <= max;
}

public static boolean rangeValue(double val, double min, double max) {
return val >= min && val <= max;
}

public static boolean rangeValue(char chars, char min, char max) {

return chars >= min && chars <= max;
}

public static boolean isExist(String val,String [] source) {

if(source == null || source.length == 0)
return false;

for(String str : source){
if(str != null && str.equals(val)){
return true;
}
}

return false;
}

public static boolean isExist(String val,List<String> source) {

if(source == null || source.size() == 0)
return false;

for(String str : source){
if(str != null && str.equals(val)){
return true;
}
}

return false;
}
}
分享到:
评论

相关推荐

    Python+PySide6开发Excel数据校验工具源代码.zip

    在进行数据分析或者数据挖掘、机器学习、深度学习之时,数据的正确性十分重要,因此在数据分析之前,进行数据正确性校验是十分必要的,基于此,本文实现了一款批量数据校验工具,可以完成:身份证校验、座机电话校验...

    springmvc数据验证jar包

    在Java Web开发中,Spring MVC框架提供了一种优雅的方式来处理控制器方法中的数据验证。这个"springmvc数据验证jar包"正是为了实现这一功能而必备的组件。它包含了多个关键库,如Hibernate Validator、JBoss Logging...

    WPF之ValidationRule数据校验

    `ValidationRule` 是WPF中实现数据验证的一种机制,它允许开发者定义自定义的校验规则来检查用户输入的数据。在本文中,我们将深入探讨`ValidationRule`的工作原理以及如何在WPF应用中实现数据校验。 ### 数据验证...

    《在kettle中实现数据验证和检查》示例代码

    本示例代码着重于在Kettle中实现数据验证和检查,这对于确保数据质量和准确性至关重要。 数据验证是数据管理过程中的关键步骤,其目的是确保输入的数据符合预定义的规则和标准,例如,检查数据完整性、一致性、合法...

    Java 使用poi导入excel 并使用xml做数据验证

    Excel中的数据验证可以通过设置数据验证规则来实现,这些规则通常存储在Excel文件的`.xlsx`包中的`sharedStrings.xml`和`workbook.xml`等文件中。在Java中,我们可以使用`DataValidationHelper`和`...

    WPF前台数据验证(红框)

    WPF前台数据验证(红框)(包括3.5和4.0两个版本) WPF 显示验证错误的默认方式是在控件周围绘制红色边框。通常需要对此方法进行自定义,以通过其他方式来显示错误。而且,默认情况下不会显示与验证错误关联的错误...

    struts2 简单数据校验

    这篇博客“Struts2 简单数据校验”可能详细介绍了如何在Struts2框架中实现对用户输入的有效性验证。 数据校验是任何Web应用程序中的核心部分,它涉及到多个方面,如必填字段、数据类型检查、长度限制、格式验证等。...

    PLC数据校验助手

    总的来说,这个PLC数据校验助手是一个针对工业自动化领域设计的实用工具,它能帮助工程师和技术人员在PLC和单片机通讯中有效地验证数据的准确性,从而提高系统的稳定性和可靠性。通过理解和使用这样的工具,可以提升...

    easyexcel+validation excel导入导出下载

    5. **数据校验**:Validation是Java中用于数据验证的框架,如使用JSR-303/JSR-349(Bean Validation)标准,我们可以为实体类的属性添加校验注解,如@NotNull、@Size、@Pattern等,然后在导入数据时,通过Validator...

    数据校验官方文档

    总体来说,这份官方文档是Java开发中实现数据校验不可或缺的参考资料,它不仅覆盖了约束校验的基础知识,还深入探讨了校验过程中的各种高级特性,对于任何希望提升Java应用数据校验能力的开发者来说,都是一份宝贵的...

    页面的数据校验JS和HTML

    页面数据校验是Web应用程序中的一个关键环节,它有助于确保用户提交的数据符合预期的格式、类型和范围,从而避免了后续处理阶段可能出现的问题。例如,如果一个表单字段预期接收的是电子邮件地址,那么通过前端校验...

    数据校验框架在hybris中的使用

    本文将详细介绍如何在Hybris中利用数据校验框架进行有效的数据验证。 1. 背景 在传统的开发方式中,数据校验通常通过编写if语句来实现,这不仅增加了代码量,而且难以维护。在接口开发中,针对各种请求数据的格式...

    MySQL主从数据校验工具

    MySQL主从数据校验工具是数据库管理中一个关键的组件,尤其在分布式系统或高可用性设置中,如主从复制架构。这类工具的主要目的是确保主数据库与从数据库之间的数据一致性,防止因网络延迟、错误同步或其他问题导致...

    Excel 数据校验项目的设计分享

    此外,还可以通过数据验证规则实现复杂的条件校验,如必须大于某个值或小于另一个值,或者参照其他单元格的数据。这些规则可以应用到单个单元格,也可以扩展到整个表格,确保数据的完整性。 在更高级的应用中,我们...

    java解析excel并做数据有效性校验

    在Excel中,可以通过设置数据验证规则实现。在Java中,我们可以使用Apache POI的`DataValidationHelper`和`DataValidationConstraint`类来创建和应用这些规则。 例如,检查手机号码的代码: ```java ...

    WPF使用IDataErrorInfo进行数据校验

    `IDataErrorInfo`接口是WPF提供的一种实现自定义数据验证规则的方法。下面我们将深入探讨如何使用`IDataErrorInfo`来进行数据校验。 首先,让我们理解`IDataErrorInfo`接口。这个接口包含两个成员:`string Error`...

    批量导入Excel数据到数据库,带数据校验/事务回滚

    数据校验是保证数据质量的关键步骤,可以使用各种验证规则。例如,可以编写自定义验证函数,针对每个字段进行特定的检查,或者利用.NET的`Validator`类进行更复杂的业务逻辑验证。 总结来说,批量导入Excel数据到...

    数据校验的一个很好的程序

    它可能包含静态方法,用于简化数据验证过程,如批量验证或自定义验证逻辑。 2. `CompareValidator.cs`: ASP.NET中的`CompareValidator`控件用于比较两个输入控件的值或者输入控件的值与一个固定的值。它可以执行...

    JSR303+AOP数据校验

    JSR303,后来在JSR349中升级为Bean Validation 1.1,提供了注解驱动的数据验证功能。开发者可以使用诸如`@NotNull`, `@Size`, `@Min`, `@Max`等预定义的验证注解,直接在实体类的属性上声明验证规则。例如,如果你有...

Global site tag (gtag.js) - Google Analytics