PHP 中检查或过滤IP地址的实现代码

 2025-01-16  阅读 320  评论 8  点赞 349

摘要:你可以通过增加一个配置文件,然后将需要禁止的一些 ip 地址通过一定规则添加到配置文件中,在程序初始化的时候,读取配置文件中的每个规则,然后通过本文提供的方法去检查当前访问的客户端 ip 地址是否存在于这些规则中,如果存在,则拒绝提供服务。 复制代码 代码如下: 由于
你可以通过增加一个配置文件,然后将需要禁止的一些 ip 地址通过一定规则添加到配置文件中,在程序初始化的时候,读取配置文件中的每个规则,然后通过本文提供的方法去检查当前访问的客户端 ip 地址是否存在于这些规则中,如果存在,则拒绝提供服务。
复制代码 代码如下:

<?php
/**
* php 中检查或过滤 ip 地址
*
* 支持 ip 区间、cidr(classless inter-domain routing)及单个 ip 格式
* 整理:http://www.codebit.cn
* 参考:
* - {@link http://us2.php.net/manual/zh/function.ip2long.php#70055}
* - {@link http://us2.php.net/manual/zh/function.ip2long.php#82397}
*
* @param string $network 网段,支持 ip 区间、cidr及单个 ip 格式
* @param string $ip 要检查的 ip 地址
* @return boolean
*/
function netmatch($network, $ip) {
$network = trim($network);
$ip = trim($ip);
$result = false;
// ip range : 174.129.0.0 - 174.129.255.255
if (false !== ($pos = strpos($network, "-"))) {
$from = ip2long(trim(substr($network, 0, $pos)));
$to = ip2long(trim(substr($network, $pos+1)));
$ip = ip2long($ip);
$result = ($ip >= $from and $ip <= $to);
// cidr : 174.129.0.0/16
} else if (false !== strpos($network,"/")) {
list ($net, $mask) = explode ('/', $network);
$result = (ip2long($ip) & ~((1 << (32 - $mask)) - 1)) == ip2long($net);
// single ip
} else {
$result = $network === $ip;
}
return $result;
}
// 174.129.0.0 - 174.129.255.255
var_dump(netmatch(' 174.129.0.0 - 174.129.255.255 ', '174.129.1.31')); // true
var_dump(netmatch(' 174.129.0.0/16 ', '174.139.1.31')); // false
var_dump(netmatch(' 174.129.1.32 ', '174.129.1.31')); // false
?>

由于中国使用的大多数都是动态 ip 地址,所以通过 ip 地址限制访问具有一定的局限性,使用的时候需要谨慎,但是对于应急限制访问来说,还是非常有用的。
标签:phpphp教程

评论列表:

显示更多评论

发表评论:

管理员

承接各种程序开发,外贸网站代运营,外贸网站建设等项目
  • 内容2460
  • 积分67666
  • 金币86666

Copyright © 2024 LS'Blog-保定PHP程序员老宋个人博客 Inc. 保留所有权利。 Powered by LS'blog 3.0.3

页面耗时0.0285秒, 内存占用1.94 MB, 访问数据库30次

冀ICP备19034377号