Class DomainValidator
- All Implemented Interfaces:
- Serializable
Domain name validation routines.
This validator provides methods for validating Internet domain names and top-level domains.
Domain names are evaluated according to the standards RFC1034, section 3, and RFC1123, section 2.1. No accommodation is provided for the specialized needs of other applications; if the domain name has been URL-encoded, for example, validation will fail even though the equivalent plaintext version of the same name would have passed.
Validation is also provided for top-level domains (TLDs) as defined and maintained by the Internet Assigned Numbers Authority (IANA):
- isValidInfrastructureTld(java.lang.String)- validates infrastructure TLDs (- .arpa, etc.)
- isValidGenericTld(java.lang.String)- validates generic TLDs (- .com, .org, etc.)
- isValidCountryCodeTld(java.lang.String)- validates country code TLDs (- .us, .uk, .cn, etc.)
 (NOTE: This class does not provide IP address lookup for domain names or
 methods to ensure that a given domain name matches a specific IP; see
 InetAddress for that functionality.)
 
- Since:
- Validator 1.4
- Version:
- $Revision$
- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic enumenum used byupdateTLDOverride(DomainValidator.ArrayType, String[])to determine which override array to update / fetchstatic classUsed to specify overrides when creating a new class.
- 
Method SummaryModifier and TypeMethodDescriptionstatic DomainValidatorReturns the singleton instance of this validator.static DomainValidatorgetInstance(boolean allowLocal) Returns the singleton instance of this validator, with local validation as required.static DomainValidatorgetInstance(boolean allowLocal, List<DomainValidator.Item> items) Returns a new instance of this validator.String[]Get a copy of an instance level internal array.static String[]Get a copy of a class level internal array.booleanDoes this instance allow local addresses?booleanReturns true if the specifiedStringparses as a valid domain name with a recognized top-level domain.booleanisValidCountryCodeTld(String ccTld) Returns true if the specifiedStringmatches any IANA-defined country code top-level domain.booleanisValidGenericTld(String gTld) Returns true if the specifiedStringmatches any IANA-defined generic top-level domain.booleanReturns true if the specifiedStringmatches any IANA-defined infrastructure top-level domain.booleanisValidLocalTld(String lTld) Returns true if the specifiedStringmatches any widely used "local" domains (localhost or localdomain).booleanisValidTld(String tld) Returns true if the specifiedStringmatches any IANA-defined top-level domain.static StringunicodeToASCII(String input) Converts potentially Unicode input to punycode.static voidupdateTLDOverride(DomainValidator.ArrayType table, String[] tlds) Update one of the TLD override arrays.
- 
Method Details- 
getInstanceReturns the singleton instance of this validator. It will not consider local addresses as valid.- Returns:
- the singleton instance of this validator
 
- 
getInstanceReturns the singleton instance of this validator, with local validation as required.- Parameters:
- allowLocal- Should local addresses be considered valid?
- Returns:
- the singleton instance of this validator
 
- 
getInstanceReturns a new instance of this validator. The user can provide a list ofDomainValidator.Itementries which can be used to override the generic and country code lists. Note that any such entries override values provided by theupdateTLDOverride(DomainValidator.ArrayType, String[])method If an entry for a particular type is not provided, then the class override (if any) is retained.- Parameters:
- allowLocal- Should local addresses be considered valid?
- items- - array of- DomainValidator.Itementries
- Returns:
- an instance of this validator
- Since:
- 1.7
 
- 
isValidReturns true if the specifiedStringparses as a valid domain name with a recognized top-level domain. The parsing is case-insensitive.- Parameters:
- domain- the parameter to check for domain name syntax
- Returns:
- true if the parameter is a valid domain name
 
- 
isValidTldReturns true if the specifiedStringmatches any IANA-defined top-level domain. Leading dots are ignored if present. The search is case-insensitive.If allowLocal is true, the TLD is checked using isValidLocalTld(String). The TLD is then checked againstisValidInfrastructureTld(String),isValidGenericTld(String)andisValidCountryCodeTld(String)- Parameters:
- tld- the parameter to check for TLD status, not null
- Returns:
- true if the parameter is a TLD
 
- 
isValidInfrastructureTldReturns true if the specifiedStringmatches any IANA-defined infrastructure top-level domain. Leading dots are ignored if present. The search is case-insensitive.- Parameters:
- iTld- the parameter to check for infrastructure TLD status, not null
- Returns:
- true if the parameter is an infrastructure TLD
 
- 
isValidGenericTldReturns true if the specifiedStringmatches any IANA-defined generic top-level domain. Leading dots are ignored if present. The search is case-insensitive.- Parameters:
- gTld- the parameter to check for generic TLD status, not null
- Returns:
- true if the parameter is a generic TLD
 
- 
isValidCountryCodeTldReturns true if the specifiedStringmatches any IANA-defined country code top-level domain. Leading dots are ignored if present. The search is case-insensitive.- Parameters:
- ccTld- the parameter to check for country code TLD status, not null
- Returns:
- true if the parameter is a country code TLD
 
- 
isValidLocalTldReturns true if the specifiedStringmatches any widely used "local" domains (localhost or localdomain). Leading dots are ignored if present. The search is case-insensitive.- Parameters:
- lTld- the parameter to check for local TLD status, not null
- Returns:
- true if the parameter is an local TLD
 
- 
isAllowLocalpublic boolean isAllowLocal()Does this instance allow local addresses?- Returns:
- true if local addresses are allowed.
- Since:
- 1.7
 
- 
updateTLDOverrideUpdate one of the TLD override arrays. This must only be done at program startup, before any instances are accessed using getInstance.For example: DomainValidator.updateTLDOverride(ArrayType.GENERIC_PLUS, new String[]{"apache"})To clear an override array, provide an empty array. - Parameters:
- table- the table to update, see- DomainValidator.ArrayTypeMust be one of the following- COUNTRY_CODE_MINUS
- COUNTRY_CODE_PLUS
- GENERIC_MINUS
- GENERIC_PLUS
- LOCAL_MINUS
- LOCAL_PLUS
 
- tlds- the array of TLDs, must not be null
- Throws:
- IllegalStateException- if the method is called after getInstance
- IllegalArgumentException- if one of the read-only tables is requested
- Since:
- 1.5.0
 
- 
getTLDEntriesGet a copy of a class level internal array.- Parameters:
- table- the array type (any of the enum values)
- Returns:
- a copy of the array
- Throws:
- IllegalArgumentException- if the table type is unexpected (should not happen)
- Since:
- 1.5.1
 
- 
getOverridesGet a copy of an instance level internal array.- Parameters:
- table- the array type (any of the enum values)
- Returns:
- a copy of the array
- Throws:
- IllegalArgumentException- if the table type is unexpected, e.g. GENERIC_RO
- Since:
- 1.7
 
- 
unicodeToASCIIConverts potentially Unicode input to punycode. If conversion fails, returns the original input.- Parameters:
- input- the string to convert, not null
- Returns:
- converted input, or original input if conversion fails
 
 
-