/*
* Copyright (c) 2002-2006 by OpenSymphony
* All rights reserved.
*/
package com.opensymphony.xwork2.validator.validators;
import com.opensymphony.xwork2.validator.ValidationException;
import com.opensymphony.xwork2.util.URLUtil;
/**
* <!-- START SNIPPET: javadoc -->
*
* URLValidator checks that a given field is a String and a valid URL
*
* <!-- 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>
* </ul>
*
* <!-- END SNIPPET: parameters -->
*
* <p/>
*
* <pre>
* <!-- START SNIPPET: examples -->
*
* <validators>
* <!-- Plain Validator Syntax -->
* <validator type="url">
* <param name="fieldName">myHomePage</param>
* <message>Invalid homepage url</message>
* </validator>
*
* <!-- Field Validator Syntax -->
* <field name="myHomepage">
* <message>Invalid homepage url</message>
* </field>
* </validators>
*
* <!-- END SNIPPET: examples -->
* </pre>
*
*
* @author $Author: musachy $
* @version $Date: 2009-03-18 18:40:42 +0100 (Mi, 18 Mär 2009) $ $Revision: 1946 $
*/
public class URLValidator extends FieldValidatorSupport {
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 || value.toString().length() == 0) {
return;
}
if (!(value.getClass().equals(String.class)) || !URLUtil.verifyUrl((String) value)) {
addFieldError(fieldName, object);
}
}
}
|