org.filesys.util.IPAddress Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jfileserver Show documentation
Show all versions of jfileserver Show documentation
Java file server with SMB, FTP/FTPS and NFS support, virtual filesystems, database filesystems
The newest version!
/*
* Copyright (C) 2006-2010 Alfresco Software Limited.
*
* This file is part of Alfresco
*
* Alfresco is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Alfresco is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Alfresco. If not, see .
*/
package org.filesys.util;
import java.net.InetAddress;
import java.util.StringTokenizer;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import java.util.regex.PatternSyntaxException;
/**
* TCP/IP Address Utility Class
*
* @author gkspencer
*/
public class IPAddress {
// Regular expressions to match IPv4 and IPv6 addresses
private static Pattern VALID_IPV4_PATTERN = null;
private static Pattern VALID_IPV6_PATTERN = null;
private static final String ipv4Pattern = "(([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\.){3}([01]?\\d\\d?|2[0-4]\\d|25[0-5])";
private static final String ipv6Pattern = "([0-9a-f]{1,4}:){7}([0-9a-f]){1,4}";
// Static initializer
static {
try {
VALID_IPV4_PATTERN = Pattern.compile(ipv4Pattern, Pattern.CASE_INSENSITIVE);
VALID_IPV6_PATTERN = Pattern.compile(ipv6Pattern, Pattern.CASE_INSENSITIVE);
} catch (PatternSyntaxException ex) {
//Debug.println("Unable to compile pattern, ex=", ex);
}
}
/**
* Check if the specified address is a valid numeric TCP/IP address
*
* @param ipaddr String
* @return boolean
*/
public static boolean isNumericAddress(String ipaddr) {
// Check if the string is valid
if (ipaddr == null || ipaddr.length() < 7 || ipaddr.length() > 15)
return false;
// Check the address string, should be n.n.n.n format
StringTokenizer token = new StringTokenizer(ipaddr, ".");
if (token.countTokens() != 4)
return false;
while (token.hasMoreTokens()) {
// Get the current token and convert to an integer value
String ipNum = token.nextToken();
try {
int ipVal = Integer.valueOf(ipNum).intValue();
if (ipVal < 0 || ipVal > 255)
return false;
}
catch (NumberFormatException ex) {
return false;
}
}
// Looks like a valid IP address
return true;
}
/**
* Check if the specified address is a valid numeric TCP/IP address and return as an integer value
*
* @param ipaddr String
* @return int
*/
public static int parseNumericAddress(String ipaddr) {
// Check if the string is valid
if (ipaddr == null || ipaddr.length() < 7 || ipaddr.length() > 15)
return 0;
// Check the address string, should be n.n.n.n format
StringTokenizer token = new StringTokenizer(ipaddr, ".");
if (token.countTokens() != 4)
return 0;
int ipInt = 0;
while (token.hasMoreTokens()) {
// Get the current token and convert to an integer value
String ipNum = token.nextToken();
try {
// Validate the current address part
int ipVal = Integer.valueOf(ipNum).intValue();
if (ipVal < 0 || ipVal > 255)
return 0;
// Add to the integer address
ipInt = (ipInt << 8) + ipVal;
}
catch (NumberFormatException ex) {
return 0;
}
}
// Return the integer address
return ipInt;
}
/**
* Convert an IP address into an integer value
*
* @param ipaddr InetAddress
* @return int
*/
public static int asInteger(InetAddress ipaddr) {
// Get the address as an array of bytes
byte[] addrBytes = ipaddr.getAddress();
// Build an integer value from the bytes
return DataPacker.getInt(addrBytes, 0);
}
/**
* Check if the specified address is within the required subnet
*
* @param ipaddr String
* @param subnet String
* @param mask String
* @return boolean
*/
public static boolean isInSubnet(String ipaddr, String subnet, String mask) {
// Convert the addresses to integer values
int ipaddrInt = parseNumericAddress(ipaddr);
if (ipaddrInt == 0)
return false;
int subnetInt = parseNumericAddress(subnet);
if (subnetInt == 0)
return false;
int maskInt = parseNumericAddress(mask);
if (maskInt == 0)
return false;
// Check if the address is part of the subnet
if ((ipaddrInt & maskInt) == subnetInt)
return true;
return false;
}
/**
* Convert a raw IP address array as a String
*
* @param ipaddr byte[]
* @return String
*/
public static String asString(byte[] ipaddr) {
// Check if the address is valid
if (ipaddr == null || ipaddr.length != 4)
return null;
// Convert the raw IP address to a string
StringBuffer str = new StringBuffer();
str.append((int) (ipaddr[0] & 0xFF));
str.append(".");
str.append((int) (ipaddr[1] & 0xFF));
str.append(".");
str.append((int) (ipaddr[2] & 0xFF));
str.append(".");
str.append((int) (ipaddr[3] & 0xFF));
// Return the address string
return str.toString();
}
/**
* Convert a raw IP address array as a String
*
* @param ipaddr int
* @return String
*/
public static String asString(int ipaddr) {
byte[] ipbyts = new byte[4];
ipbyts[0] = (byte) ((ipaddr >> 24) & 0xFF);
ipbyts[1] = (byte) ((ipaddr >> 16) & 0xFF);
ipbyts[2] = (byte) ((ipaddr >> 8) & 0xFF);
ipbyts[3] = (byte) (ipaddr & 0xFF);
return asString(ipbyts);
}
/**
* Convert a TCP/IP address string into a byte array
*
* @param addr String
* @return byte[]
*/
public static byte[] asBytes(String addr) {
// Convert the TCP/IP address string to an integer value
int ipInt = parseNumericAddress(addr);
if (ipInt == 0)
return null;
// Convert to bytes
byte[] ipByts = new byte[4];
ipByts[3] = (byte) (ipInt & 0xFF);
ipByts[2] = (byte) ((ipInt >> 8) & 0xFF);
ipByts[1] = (byte) ((ipInt >> 16) & 0xFF);
ipByts[0] = (byte) ((ipInt >> 24) & 0xFF);
// Return the TCP/IP bytes
return ipByts;
}
/**
* Check if an address string is a valid IPv4 address
*
* @param addr String
* @return boolean
*/
public static boolean isIPv4Address(String addr) {
Matcher ipv4 = VALID_IPV4_PATTERN.matcher(addr);
return ipv4.matches();
}
/**
* Check if an address string is a valid IPv6 address
*
* @param addr String
* @return boolean
*/
public static boolean isIPv6Address(String addr) {
// Check if the address contains a scope index
int idx = addr.indexOf( '%');
if ( idx != -1)
addr = addr.substring(0, idx);
Matcher ipv6 = VALID_IPV6_PATTERN.matcher(addr);
return ipv6.matches();
}
}