All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sf.hajdbc.util.NetMasks Maven / Gradle / Ivy

package net.sf.hajdbc.util;

import java.net.InetAddress;
import java.net.UnknownHostException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * 网络掩码计算工具
 * @author yangzj
 *
 */
public class NetMasks {
  static Logger logger = LoggerFactory.getLogger(NetMasks.class);
  
  public static short getPrefixLen(String ipString){
    InetAddress address = fromIp(ipString);
    return getPrefixLen(address);
  }

  private static InetAddress fromIp(String ipString) {
    try {
      return InetAddress.getByName(ipString);
    } catch (UnknownHostException e) {
      logger.warn("",e);
    }
    return null;
  }

  public static short getPrefixLen(InetAddress address){
    short prefixLen = 0;
    byte[] addr = address.getAddress();
    for(byte addr_b : addr){
      int b = (int)addr_b;
      if((b & 0x80) > 0 ){
        prefixLen++;
      }else{
        break;
      }
      if((b & 0x40) > 0 ){
        prefixLen++;
      }else{
        break;
      }
      if((b & 0x20) > 0 ){
        prefixLen++;
      }else{
        break;
      }
      if((b & 0x10) > 0 ){
        prefixLen++;
      }else{
        break;
      }
      if((b & 0x08) > 0 ){
        prefixLen++;
      }else{
        break;
      }
      if((b & 0x04) > 0 ){
        prefixLen++;
      }else{
        break;
      }
      if((b & 0x02) > 0 ){
        prefixLen++;
      }else{
        break;
      }
      if((b & 0x01) > 0 ){
        prefixLen++;
      }else{
        break;
      }
    }
    return prefixLen;
  }
  
  
  public static String getMaskString(short prefixLen){
    InetAddress mask = getMask(prefixLen);
    return mask!=null?mask.getHostAddress():"";
  }
  
  public static InetAddress getMask(short prefixLen)
  {
    InetAddress mask = null;
    int addrLen = 4;
    byte[] addr = new byte[addrLen];

    for (int i = 0; i < addrLen; i++) {
      int offset = 8 * i;
      if (prefixLen > offset) {
        if (prefixLen < offset + 8) {
          addr[i] = (byte) (0xff << (8 + offset - prefixLen));
        } else {
          addr[i] = (byte) 0xff;
        }
      } else {
        addr[i] = 0x00;
      }
    }
    try {
      mask=InetAddress.getByAddress(addr);
    } catch (UnknownHostException e) {
      logger.warn("",e);
    }
    return mask;
  }
  
  public static String getBroadcastString(String ipString,short prefixLen)
  {
    return getBroadcastString(fromIp(ipString),prefixLen);
  }
  
  public static String getBroadcastString(InetAddress address,short prefixLen)
  {
    InetAddress broadcast = getBroadcast(address, prefixLen);
    return broadcast!=null?broadcast.getHostAddress():"";
  }
  
  
  public static InetAddress getBroadcast(String ipString, short prefixLen)
  {
    return getBroadcast(fromIp(ipString), prefixLen);
  }
  
  public static InetAddress getBroadcast(InetAddress address, short prefixLen)
  {
    InetAddress broadcast = null;
    byte[] addr = address.getAddress();
    int addrLen = addr.length;
    byte[] baddr = new byte[addrLen];
    for (int i = 0; i < addrLen; i++) {
      int offset = 8 * i;
      if (prefixLen > offset) {
        if (prefixLen < offset + 8) {
          baddr[i] = (byte) (addr[i] & (0xff << (8 + offset - prefixLen)));
        } else {
          baddr[i] = addr[i];
        }
      } else {
        baddr[i] = (byte)0xff;
      }
    }
    try {
      broadcast = InetAddress.getByAddress(baddr);
    } catch (UnknownHostException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }
    return broadcast;
  }
  
  public static boolean isSameSubnet(short prefixLen,InetAddress address1,InetAddress address2){
    boolean sameSubnet = false;
    sameSubnet = getBroadcast(address1,prefixLen).equals(getBroadcast(address2,prefixLen));
    return sameSubnet;
  }
  
  public static boolean isSameSubnet(short prefixLen,String ip1,String ip2){
    boolean sameSubnet = false;
    sameSubnet = getBroadcast(ip1,prefixLen).equals(getBroadcast(ip2,prefixLen));
    return sameSubnet;
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy