- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以下面的代码是另一位用户不久前发布的。
我想知道在 "net['firstip']
和 net['lastip']"
之间获取每个 IP 地址的最佳方法是什么?
我尝试了几种从十进制转换为二进制的方法,但没有用。我的想法是 for()
增加二进制 firstip
直到它到达 lastip
,然后将每一步转换为十进制等效于放入新数组。
感谢所有帮助。我将 *** 放在我试图找到 IP 之间的两个特定部分。
function zerofill($val,$len,$reverse = false){
while(strlen($val)<$len)
if($reverse)
$val .= "0";
else
$val = "0".$val;
return $val;
}
function hextoip($hex){
for($i=0;$i<4;$i++)
@$ip .= base_convert(substr($hex,$i*2,2),16,10).".";
$ip = substr($ip,0,-1);
return $ip;
}
function iptohex($ip){
$iparr = explode(".",$ip);
foreach($iparr as $i => $group){
@$hex .= zerofill(base_convert($group,10,16),2);
}
return $hex;
}
function hextobin($hex){
$bin = zerofill(base_convert($hex,16,2),32);
return $bin;
}
function bintohex($bin) {
$hex = zerofill(base_convert($bin,2,16),8);
return $hex;
}
function getnet($ip, $netmask){
$iphex = iptohex($ip);
$netbin = hextobin($iphex);
$maskhex = iptohex($netmask);
$maskbin = hextobin($maskhex);
$hostbits = substr($maskbin,strpos($maskbin,"0"));
$netbits = substr($maskbin,0,strpos($maskbin,"0"));
$nethex = bintohex(zerofill(substr($netbin,0,strlen($netbits)),32,true));
$hosts = pow(2,strlen($hostbits));
$available_hosts = $hosts-3;
$net["ip"] = $ip;
$net["mask"] = $netmask;
$net["network"] = hextoip($nethex);
$net["netstr"] = $net["network"]."/".strlen($netbits);
$net["hosts"] = $available_hosts;
*** $net["firstip"] = hextoip(zerofill(base_convert(base_convert($nethex,16,10)+1,10,16),8));;
*** $net["lastip"] = hextoip(zerofill(base_convert(base_convert($nethex,16,10)+$available_hosts+1,10,16),8));
$net["broadcast"] = hextoip(zerofill(base_convert(base_convert($nethex,16,10)+$available_hosts+2,10,16),8));
return $net;
} `
最佳答案
您可以使用以下代码从第一个IP到最后一个IP获取所有IP:
<?php
function getIpRange( $cidr) {
list($ip, $mask) = explode('/', $cidr);
$maskBinStr =str_repeat("1", $mask ) . str_repeat("0", 32-$mask ); //net mask binary string
$inverseMaskBinStr = str_repeat("0", $mask ) . str_repeat("1", 32-$mask ); //inverse mask
$ipLong = ip2long( $ip );
$ipMaskLong = bindec( $maskBinStr );
$inverseIpMaskLong = bindec( $inverseMaskBinStr );
$netWork = $ipLong & $ipMaskLong;
$start = $netWork+1;//ignore network ID(eg: 192.168.1.0)
$end = ($netWork | $inverseIpMaskLong) -1 ; //ignore brocast IP(eg: 192.168.1.255)
return array('firstIP' => $start, 'lastIP' => $end );
}
function getEachIpInRange ( $cidr) {
$ips = array();
$range = getIpRange($cidr);
for ($ip = $range['firstIP']; $ip <= $range['lastIP']; $ip++) {
$ips[] = long2ip($ip);
}
return $ips;
}
$cidr = '172.16.0.0/27'; // max. 30 ips
print_r(getEachIpInRange ( $cidr));
/* output:
Array
(
[0] => 172.16.0.1
[1] => 172.16.0.2
[2] => 172.16.0.3
...
[27] => 172.16.0.28
[28] => 172.16.0.29
[29] => 172.16.0.30
)
*/
如果您需要更多信息,请在此处查看 PHP 手册:http://php.net/manual/de/function.ip2long.php
我的示例代码中的某些部分来自本手册。
关于php - 如何获取子网中的每个IP地址?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27671953/
因此,AWS 中私有(private)子网的目的是使其实例无法从外部世界直接访问。然而,在某些情况下(成功地抵制了“实例”双关语),实例访问互联网很有用。例如,一种这样的用例可能是下载软件更新。 实现
我已经退出虚拟机,我需要更改该虚拟机的虚拟网络/子网。我没有找到任何可以更改的选项,请帮助我。谢谢..! 最佳答案 据我所知,当在 VNet 中创建 NIC 时,它就无法再移动到另一个 VNet。因此
我想导出一些内容,例如 VNET 中存在的子网 View (如门户中显示的那样)。不幸的是,没有选项可以将其导出为 CSV。我在网上找到了可以导出子网路由表和关联子网的 powershell 脚本。我
我的虚拟网络具有以下子网 10.0.0.0/24,我想添加另一个子网,但每次尝试时都会得到:“您的子网不包含在该虚拟网络的同一地址空间内” 如何添加另一个子网? 最佳答案 您可以在虚拟网络中添加子网,
我有 ip 地址列表作为字符串,但该列表中也有一些子网。例如: ...127.0.0.1(这是ip)127.0.0.1/24(这是子网)... 我想检查哪个是ip,哪个是子网。到目前为止我可以过滤 i
我正在尝试使用 ARM 模板部署 Azure 防火墙。该模板在首次部署期间工作正常,并在现有虚拟网络中创建一个子网(根据需要命名为 AzureFirewallSubnet)以及具有公共(public)
我正在尝试使用 ARM 模板部署 Azure 防火墙。该模板在首次部署期间工作正常,并在现有虚拟网络中创建一个子网(根据需要命名为 AzureFirewallSubnet)以及具有公共(public)
我正在尝试编写一个脚本,将大于(不大于/16)大于/24 的子网分解为/24 子网。例如:10.10.10.0/23 应该给我 10.10.10.0/24 和 10.10.11.0/24 我的逻辑是首
我在 Azure VNet 中有两台虚拟机(IP 地址 10.1.0.4 和 10.1.0.5),以及一台通过 VPN 网关连接到 VNet 的计算机(IP 10.3.0.2)。是否可以在内部负载均衡
错误消息 执行terraform apply时收到以下错误消息: 错误:创建/更新虚拟网络“CTI-NETWORK”(资源组“CTI-RESOURCES”)时出错:network.VirtualNet
我无法从不再使用的 VNet 中删除“默认”子网。错误是:“子网默认值由/subscriptions/{guid}/resourceGroups/mpi-prod-westeurope-rg/prov
我在使用 docker-compose 时遇到问题。目前,我的容器堆栈是在它们自己定制的、基于桥接的隔离网络中创建的。 例如当运行 docker-compose -p client1 up -d 时,
我无法从不再使用的 VNet 中删除“默认”子网。错误是:“子网默认值由/subscriptions/{guid}/resourceGroups/mpi-prod-westeurope-rg/prov
如果文件的一个版本在特定子网中具有接口(interface),我想将其复制到服务器,或者如果在该子网中没有接口(interface),则将文件的一个版本复制到服务器。下面是一个工作,但我认为不是最佳解
我是 terraform 新手,想要更改网络上的子网,但遇到了一个奇怪的错误。谷歌什么也没得到。这是我要输入的内容(更改 main.tf 和运行计划后) terraform apply -replac
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a software
我们有 dbs, basion ..等,总共 10 个东西需要分开。 如果我们将它们中的每一个都放入一个单独的子网中,我们总共有 10 个子网,再加上 1 个用于第二个区域以实现高可用性。因此,我们总
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a software
我们有 dbs, basion ..等,总共 10 个东西需要分开。 如果我们将它们中的每一个都放入一个单独的子网中,我们总共有 10 个子网,再加上 1 个用于第二个区域以实现高可用性。因此,我们总
在 IP 为 145.74.217.109 的机器 A 上运行 ServerSocket 时然后尝试使用 IP 为 145.74.219.103 的机器 B 连接到机器 A,但无法连接。但是当使用 I
我是一名优秀的程序员,十分优秀!