當前位置: 首頁>>代碼示例>>Java>>正文


Java SubnetUtils.setInclusiveHostCount方法代碼示例

本文整理匯總了Java中org.apache.commons.net.util.SubnetUtils.setInclusiveHostCount方法的典型用法代碼示例。如果您正苦於以下問題:Java SubnetUtils.setInclusiveHostCount方法的具體用法?Java SubnetUtils.setInclusiveHostCount怎麽用?Java SubnetUtils.setInclusiveHostCount使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.commons.net.util.SubnetUtils的用法示例。


在下文中一共展示了SubnetUtils.setInclusiveHostCount方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: isIpInValidRange

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
/**
 * If the ip is in the same network as the cidr, it returns true
 *
 * @param ipAddress The ip address under test
 * @param cidr      The cidr that defines the expected network address
 * @param ipVersion
 * @return
 */
public static boolean isIpInValidRange(String ipAddress,
        String cidr, IPVersion ipVersion) {

    if (!IPVersion.IPv4.equals(ipVersion)) {
        throw new UnsupportedOperationException(
                "Support for IPv6 IP address is not yet implemented");
    }

    SubnetUtils utils = new SubnetUtils(cidr);
    utils.setInclusiveHostCount(true);

    if (!utils.getInfo().getAddress().equals(utils.getInfo().getNetworkAddress())) {
        String err = String.format("Invalid CIDR: %s. Host identifier of the"
                + " CIDR contains non zero bits.", cidr);
        throw new RuntimeException(err);
    }

    return utils.getInfo().isInRange(ipAddress);

}
 
開發者ID:vmware,項目名稱:photon-model,代碼行數:29,代碼來源:SubnetValidator.java

示例2: isIpWithtInCidrRange

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
public static boolean isIpWithtInCidrRange(final String ipAddress, final String cidr) {
    if (!isValidIp4(ipAddress)) {
        return false;
    }
    if (!isValidIp4Cidr(cidr)) {
        return false;
    }
    if (cidr.equals("0.0.0.0/0")) {
        return true;
    }

    // check if the gatewayip is the part of the ip range being added.
    // RFC 3021 - 31-Bit Prefixes on IPv4 Point-to-Point Links
    //     GW              Netmask         Stat IP        End IP
    // 192.168.24.0 - 255.255.255.254 - 192.168.24.0 - 192.168.24.1
    // https://tools.ietf.org/html/rfc3021
    // Added by Wilder Rodrigues
    final SubnetUtils subnetUtils = new SubnetUtils(cidr);
    subnetUtils.setInclusiveHostCount(true);

    final boolean isInRange = subnetUtils.getInfo().isInRange(ipAddress);

    return isInRange;
}
 
開發者ID:MissionCriticalCloud,項目名稱:cosmic,代碼行數:25,代碼來源:NetUtils.java

示例3: testThatFilterAndTruncateViolatorsFiltersIPsInDoNotBlockRangeSet

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
@Test
public void testThatFilterAndTruncateViolatorsFiltersIPsInDoNotBlockRangeSet() {
    config.setRateLimitViolationBlacklistPeriodInMinutes(1);
    RangeSet<Integer> doNotAutoBlockIpRangeSet = TreeRangeSet.create();

    SubnetUtils subnetUtils = new SubnetUtils("50.39.100.193/32");
    subnetUtils.setInclusiveHostCount(true);
    SubnetUtils.SubnetInfo subnetInfo = subnetUtils.getInfo();
    Integer lowIpAsInt = subnetInfo.asInteger(subnetInfo.getLowAddress());
    Integer highIpAsInt = subnetInfo.asInteger(subnetInfo.getHighAddress());
    doNotAutoBlockIpRangeSet.add(Range.closed(lowIpAsInt, highIpAsInt));

    Map<String, ViolationMetaData> violators = new HashMap<>();
    violators.put("50.39.100.193", new ViolationMetaData(new Date(), 2));
    Map<String, ViolationMetaData> actual = processor.filterAndTruncateViolators(config, doNotAutoBlockIpRangeSet,
            violators);

    assertTrue("The violators map should be empty after filtering", actual.size() == 0);
}
 
開發者ID:Nike-Inc,項目名稱:cerberus-serverless-components,代碼行數:20,代碼來源:RateLimitingProcessorTest.java

示例4: testThatProcessViolatorsDoesNotReAddWhatIsAlreadyBlocked

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
@Test
public void testThatProcessViolatorsDoesNotReAddWhatIsAlreadyBlocked() {
    String fakeIpSet = "foo";
    config.setRateLimitAutoBlackListIpSetId(fakeIpSet);

    List<SubnetUtils.SubnetInfo> currentlyAutoBlocked = new LinkedList<>();
    SubnetUtils subnetUtils = new SubnetUtils("192.168.0.1/32");
    subnetUtils.setInclusiveHostCount(true);
    SubnetUtils.SubnetInfo info = subnetUtils.getInfo();
    currentlyAutoBlocked.add(info);

    doReturn(currentlyAutoBlocked).when(processor).getIpSet(fakeIpSet);

    Map<String, ViolationMetaData> violators = new HashMap<>();
    violators.put("192.168.0.1", new ViolationMetaData(new Date(), 10));

    processor.processViolators(config, violators);

    verify(awswaf, times(0)).updateIPSet(isA(UpdateIPSetRequest.class));
}
 
開發者ID:Nike-Inc,項目名稱:cerberus-serverless-components,代碼行數:21,代碼來源:RateLimitingProcessorTest.java

示例5: testThatProcessViolatorsAddsNewIpsToIpSet

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
@Test
public void testThatProcessViolatorsAddsNewIpsToIpSet() {
    String fakeIpSet = "foo";
    config.setRateLimitAutoBlackListIpSetId(fakeIpSet);
    doReturn(new LinkedList<>()).when(processor).getIpSet(fakeIpSet);
    Map<String, ViolationMetaData> violators = new HashMap<>();
    violators.put("192.168.0.1", new ViolationMetaData(new Date(), 10));

    processor.processViolators(config, violators);

    List<IPSetUpdate> expectedUpdates = new LinkedList<>();
    SubnetUtils subnetUtils = new SubnetUtils("192.168.0.1/32");
    subnetUtils.setInclusiveHostCount(true);
    SubnetUtils.SubnetInfo info = subnetUtils.getInfo();
    IPSetDescriptor descriptor = new IPSetDescriptor()
            .withType(IPSetDescriptorType.IPV4)
            .withValue(info.getCidrSignature());

    IPSetUpdate update = new IPSetUpdate().withIPSetDescriptor(descriptor).withAction(ChangeAction.INSERT);
    expectedUpdates.add(update);

    verify(awswaf, times(1)).updateIPSet(new UpdateIPSetRequest()
            .withIPSetId(config.getRateLimitAutoBlackListIpSetId())
            .withUpdates(expectedUpdates)
            .withChangeToken(CHANGE_TOKEN));
}
 
開發者ID:Nike-Inc,項目名稱:cerberus-serverless-components,代碼行數:27,代碼來源:RateLimitingProcessorTest.java

示例6: getIgpPrefixMetric

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
/**
 * Lookup the IGP metric for the prefix (e.g. next hop) passed
 *
 * @param prefix            IP in print form (this is the next-hop)
 * @param igpMap            IGP RIB map
 *
 * @return null if no match, otherwise the column def list that matches is returned
 */
List<DbColumnDef> getIgpPrefixMetric(String prefix, Map<String, List<DbColumnDef>> igpMap) {
    List<DbColumnDef> found_cols = null;

    System.out.println("Lookup IGP metric cost for prefix " + prefix);

    for(Map.Entry<String, List<DbColumnDef>> row : igpMap.entrySet()) {
        // Prefix,PrefixLen,LocalPref,ASPath_Count,Origin,MED,NH
        List<DbColumnDef> cols = row.getValue();

        SubnetUtils subU = new SubnetUtils(cols.get(0).getValue() + '/' + cols.get(1).getValue());
        subU.setInclusiveHostCount(true);

        if (subU.getInfo().isInRange(prefix)) {
            System.out.println("    Found matching prefix, metric is " + cols.get(6).getValue());
            found_cols = cols;
            break;
        }
    }

    return found_cols;
}
 
開發者ID:OpenBMP,項目名稱:db_rest,代碼行數:30,代碼來源:Orr.java

示例7: isIpWithInCidrRange

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
public static boolean isIpWithInCidrRange(final String ipAddress, final String cidr) {
    if (!isValidIp4(ipAddress)) {
        return false;
    }
    if (!isValidIp4Cidr(cidr)) {
        return false;
    }

    // check if the gatewayip is the part of the ip range being added.
    // RFC 3021 - 31-Bit Prefixes on IPv4 Point-to-Point Links
    //     GW              Netmask         Stat IP        End IP
    // 192.168.24.0 - 255.255.255.254 - 192.168.24.0 - 192.168.24.1
    // https://tools.ietf.org/html/rfc3021
    // Added by Wilder Rodrigues
    final SubnetUtils subnetUtils = new SubnetUtils(cidr);
    subnetUtils.setInclusiveHostCount(true);

    final boolean isInRange = subnetUtils.getInfo().isInRange(ipAddress);

    return isInRange;
}
 
開發者ID:apache,項目名稱:cloudstack,代碼行數:22,代碼來源:NetUtils.java

示例8: getSubnetArray

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
public final static SubnetInfo[] getSubnetArray(String ips)
		throws IOException {
	if (ips == null)
		return null;
	StringReader sr = new StringReader(ips);
	try {
		List<String> lines = IOUtils.readLines(sr);
		if (lines == null)
			return null;
		SubnetInfo[] subnetArray = new SubnetInfo[lines.size()];
		int i = 0;
		for (String line : lines) {
			line = line.trim();
			if (line.isEmpty())
				continue;
			if (line.indexOf('/') == -1)
				line = line + "/32";
			SubnetUtils subnetUtils = new SubnetUtils(line);
			subnetUtils.setInclusiveHostCount(true);
			subnetArray[i++] = subnetUtils.getInfo();
		}
		return subnetArray;
	} finally {
		IOUtils.closeQuietly(sr);
	}
}
 
開發者ID:jaeksoft,項目名稱:opensearchserver,代碼行數:27,代碼來源:NetworksUtils.java

示例9: getCidrHostAddress

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
public static String getCidrHostAddress(final String cidr) {
    final String[] cidrPair = cidr.split("\\/");
    final String address = cidrPair[0];
    final SubnetUtils subnetUtils = new SubnetUtils(cidr);
    subnetUtils.setInclusiveHostCount(false);

    if (isValidIp4(address) && subnetUtils.getInfo().isInRange(address)) {
        return address;
    }

    return null;
}
 
開發者ID:MissionCriticalCloud,項目名稱:cosmic,代碼行數:13,代碼來源:NetUtils.java

示例10: isNetworkorBroadcastIP

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
public static boolean isNetworkorBroadcastIP(final String ip, final String netmask) {
    final String cidr = getCidrFromGatewayAndNetmask(ip, netmask);
    final SubnetUtils subnetUtils = new SubnetUtils(cidr);
    subnetUtils.setInclusiveHostCount(false);
    final boolean isInRange = subnetUtils.getInfo().isInRange(ip);
    return !isInRange;
}
 
開發者ID:MissionCriticalCloud,項目名稱:cosmic,代碼行數:8,代碼來源:NetUtils.java

示例11: testThatProcessViolatorsRemovesIpsThatShouldNoLongerBeInIpSet

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
@Test
public void testThatProcessViolatorsRemovesIpsThatShouldNoLongerBeInIpSet() {
    String fakeIpSet = "foo";
    config.setRateLimitAutoBlackListIpSetId(fakeIpSet);

    List<SubnetUtils.SubnetInfo> currentlyAutoBlocked = new LinkedList<>();
    SubnetUtils subnetUtils = new SubnetUtils("192.168.0.1/32");
    subnetUtils.setInclusiveHostCount(true);
    SubnetUtils.SubnetInfo info = subnetUtils.getInfo();
    currentlyAutoBlocked.add(info);

    doReturn(currentlyAutoBlocked).when(processor).getIpSet(fakeIpSet);

    Map<String, ViolationMetaData> violators = new HashMap<>();

    processor.processViolators(config, violators);

    List<IPSetUpdate> expectedUpdates = new LinkedList<>();
    IPSetDescriptor descriptor = new IPSetDescriptor()
            .withType(IPSetDescriptorType.IPV4)
            .withValue(info.getCidrSignature());

    IPSetUpdate update = new IPSetUpdate().withIPSetDescriptor(descriptor).withAction(ChangeAction.DELETE);
    expectedUpdates.add(update);

    verify(awswaf, times(1)).updateIPSet(new UpdateIPSetRequest()
            .withIPSetId(config.getRateLimitAutoBlackListIpSetId())
            .withUpdates(expectedUpdates)
            .withChangeToken(CHANGE_TOKEN));
}
 
開發者ID:Nike-Inc,項目名稱:cerberus-serverless-components,代碼行數:31,代碼來源:RateLimitingProcessorTest.java

示例12: testThatGetDoNotBlockRangeSetBuildsARangeSet

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
@Test
public void testThatGetDoNotBlockRangeSetBuildsARangeSet() {
    // stub the black list
    String black = "black";
    config.setManualBlackListIpSetId(black);
    List<SubnetUtils.SubnetInfo> blackList = Lists.newLinkedList();
    // 192.168.0.0-192.168.0.255
    SubnetUtils bSubnetUtils = new SubnetUtils("192.168.0.0/24");
    bSubnetUtils.setInclusiveHostCount(true);
    SubnetUtils.SubnetInfo bInfo = bSubnetUtils.getInfo();
    blackList.add(bInfo);
    doReturn(blackList).when(processor).getIpSet(black);

    // stub the white list
    String white = "white";
    config.setManualWhiteListIpSetId(white);
    List<SubnetUtils.SubnetInfo> whiteList = Lists.newLinkedList();
    // 192.150.0.0-192.150.0.255
    SubnetUtils wSubnetUtils = new SubnetUtils("192.150.0.0/24");
    wSubnetUtils.setInclusiveHostCount(true);
    SubnetUtils.SubnetInfo wInfo = wSubnetUtils.getInfo();
    whiteList.add(wInfo);
    doReturn(whiteList).when(processor).getIpSet(white);

    RangeSet<Integer> doNotBlock = processor.getDoNotBlockRangeSet(config);

    SubnetUtils utils = new SubnetUtils("0.0.0.0/24");
    Integer onTheBlackListLow = utils.getInfo().asInteger("192.168.0.0");
    Integer onTheBlackListHigh = utils.getInfo().asInteger("192.168.0.255");
    Integer onTheWhiteListLow = utils.getInfo().asInteger("192.150.0.0");
    Integer onTheWhiteListHigh = utils.getInfo().asInteger("192.150.0.255");
    Integer shouldBeBlocked = utils.getInfo().asInteger("192.168.1.1");

    assertTrue("192.168.0.0 is in the ip range represented by 192.168.0.0/24 and therefor should be in the doNotBlock range set", doNotBlock.contains(onTheBlackListLow));
    assertTrue("192.168.0.255 is in the ip range represented by 192.168.0.0/24 and therefor should be in the doNotBlock range set", doNotBlock.contains(onTheBlackListHigh));
    assertTrue("192.150.0.0 is in the ip range represented by 192.150.0.0/24 and therefor should be in the doNotBlock range set", doNotBlock.contains(onTheWhiteListLow));
    assertTrue("192.150.0.255 is in the ip range represented by 192.150.0.0/24 and therefor should be in the doNotBlock range set", doNotBlock.contains(onTheWhiteListHigh));
    assertFalse("192.168.1.1 is not in 192.168.0.0/24 or 192.150.0.0/24 and should not be in the doNotBlock range set", doNotBlock.contains(shouldBeBlocked));
}
 
開發者ID:Nike-Inc,項目名稱:cerberus-serverless-components,代碼行數:40,代碼來源:RateLimitingProcessorTest.java

示例13: CriteriaIP

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
public CriteriaIP(String ipAddress, String mask, PacketDirection direction)
{
	this.ipAddress = ipAddress;
	this.direction = direction;
	
	SubnetUtils subnetUtils = new SubnetUtils(ipAddress, mask);
	subnetUtils.setInclusiveHostCount(true); //to allow one specific address with mask 255.255.255.255
	
	subnetInfo = subnetUtils.getInfo();
}
 
開發者ID:ck3ck3,項目名稱:WhoWhatWhere,代碼行數:11,代碼來源:CriteriaIP.java

示例14: getSubnetRange

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
public static String getSubnetRange(String ip, String netmask)
{
	try
	{
		SubnetUtils subnetUtils = new SubnetUtils(ip, netmask);
		subnetUtils.setInclusiveHostCount(true); //to allow one specific address with mask 255.255.255.255
		
		return subnetUtils.getInfo().getLowAddress() + " - " + subnetUtils.getInfo().getHighAddress();
	}
	catch(IllegalArgumentException iae)
	{
		return null;
	}
}
 
開發者ID:ck3ck3,項目名稱:WhoWhatWhere,代碼行數:15,代碼來源:NetworkSniffer.java

示例15: validate

import org.apache.commons.net.util.SubnetUtils; //導入方法依賴的package包/類
private void validate(APIAddIpRangeByNetworkCidrMsg msg) {
    try {
        SubnetUtils utils = new SubnetUtils(msg.getNetworkCidr());
        utils.setInclusiveHostCount(false);
        SubnetInfo subnet = utils.getInfo();
        if (subnet.getAddressCount() == 0) {
            throw new ApiMessageInterceptionException(argerr("%s is not an allowed network cidr, because it doesn't have usable ip range", msg.getNetworkCidr()));
        }
    } catch (IllegalArgumentException e) {
        throw new ApiMessageInterceptionException(argerr("%s is not a valid network cidr", msg.getNetworkCidr()));
    }

    IpRangeInventory ipr = IpRangeInventory.fromMessage(msg);
    validate(ipr);
}
 
開發者ID:zstackio,項目名稱:zstack,代碼行數:16,代碼來源:L3NetworkApiInterceptor.java


注:本文中的org.apache.commons.net.util.SubnetUtils.setInclusiveHostCount方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。