📄 regexfieldvalidator.java
字号:
/* * Copyright (c) 2002-2006 by OpenSymphony * All rights reserved. */package com.opensymphony.xwork2.validator.validators;import com.opensymphony.xwork2.validator.ValidationException;import java.util.regex.Pattern;import java.util.regex.Matcher;/** * <!-- START SNIPPET: javadoc --> * Validates a string field using a regular expression. * <!-- END SNIPPET: javadoc --> * <p/> * * * <!-- START SNIPPET: parameters --> * <ul> * <li>fieldName - The field name this validator is validating. Required if using Plain-Validator Syntax otherwise not required</li> * <li>expression - The RegExp expression REQUIRED</li> * <li>caseSensitive - Boolean (Optional). Sets whether the expression should be matched against in a case-sensitive way. Default is <code>true</code>.</li> * <li>trim - Boolean (Optional). Sets whether the expression should be trimed before matching. Default is <code>true</code>.</li> * </ul> * <!-- END SNIPPET: parameters --> * * * <pre> * <!-- START SNIPPET: example --> * <validators> * <!-- Plain Validator Syntax --> * <validator type="regex"> * <param name="fieldName">myStrangePostcode</param> * <param name="expression"><![CDATA[([aAbBcCdD][123][eEfFgG][456])]]<>/param> * </validator> * * <!-- Field Validator Syntax --> * <field name="myStrangePostcode"> * <field-validator type="regex"> * <param name="expression"><![CDATA[([aAbBcCdD][123][eEfFgG][456])]]></param> * </field-validator> * </field> * </validators> * <!-- END SNIPPET: example --> * </pre> * * @author Quake Wang * @version $Date: 2007-03-31 23:47:32 +0200 (Sat, 31 Mar 2007) $ $Revision: 1424 $ */public class RegexFieldValidator extends FieldValidatorSupport { private String expression; private boolean caseSensitive = true; private boolean trim = true; public void validate(Object object) throws ValidationException { String fieldName = getFieldName(); Object value = this.getFieldValue(fieldName, object); // if there is no value - don't do comparison // if a value is required, a required validator should be added to the field if (value == null || expression == null) { return; } // XW-375 - must be a string if (!(value instanceof String)) { return; } // string must not be empty String str = ((String) value).trim(); if (str.length() == 0) { return; } // match against expression Pattern pattern; if (isCaseSensitive()) { pattern = Pattern.compile(expression); } else { pattern = Pattern.compile(expression, Pattern.CASE_INSENSITIVE); } String compare = (String) value; if ( trim ) { compare = compare.trim(); } Matcher matcher = pattern.matcher( compare ); if (!matcher.matches()) { addFieldError(fieldName, object); } } /** * @return Returns the regular expression to be matched. */ public String getExpression() { return expression; } /** * Sets the regular expression to be matched. */ public void setExpression(String expression) { this.expression = expression; } /** * @return Returns whether the expression should be matched against in * a case-sensitive way. Default is <code>true</code>. */ public boolean isCaseSensitive() { return caseSensitive; } /** * Sets whether the expression should be matched against in * a case-sensitive way. Default is <code>true</code>. */ public void setCaseSensitive(boolean caseSensitive) { this.caseSensitive = caseSensitive; } /** * @return Returns whether the expression should be trimed before matching. * Default is <code>true</code>. */ public boolean isTrimed() { return trim; } /** * Sets whether the expression should be trimed before matching. * Default is <code>true</code>. */ public void setTrim(boolean trim) { this.trim = trim; }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -