php网站限制某些ip访,网站限制某些ip访问,仅允许指定ip地址访问

把下面的代码直接贴在index.php的开头即可。前提必须是在里才有效

代码:

function getIP() {

return

isset($_SERVER["HTTP_X_FORWARDED_FOR"])?$_SERVER["HTTP_X_FORWARDED_FOR"]

:(isset($_SERVER["HTTP_CLIENT_IP"])?$_SERVER["HTTP_CLIENT_IP"]

:$_SERVER["REMOTE_ADDR"]);

}

function check_ip(){

$ALLOWED_IP=array('127.0.0.1');//允许访问的ip地址

$IP=getIP();

$check_ip_arr= explode('.',$IP);//要检测的ip拆分成数组

#限制IP

if(!in_array($IP,$ALLOWED_IP)) {

foreach ($ALLOWED_IP as $val){

if(strpos($val,'*')!==false){//发现有*号替代符

$arr=array();//

$arr=explode('.', $val);

$bl=true;//用于记录循环检测中是否有匹配成功的

for($i=0;$i<4;$i++){

if($arr[$i]!='*'){//不等于*

就要进来检测,如果为*符号替代符就不检查

if($arr[$i]!=$check_ip_arr[$i]){

$bl=false;

break;//终止检查本个ip 继续检查下一个ip

}

}

}//end for

if($bl){//如果是true则找到有一个匹配成功的就返回

return;

die;

}

}

}//end foreach

header('HTTP/1.1 403 Forbidden');

echo "Access forbidden";

die;

}

}

check_ip();

把上面的代码直接贴在index.php的开头即可。前提必须是在里才有效

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
允许任何巴西的IP访问,并限制其他所有IP访问,你可以在ThinkPHP项目中进行以下配置: 1. 打开项目根目录下的`public`文件夹,找到`index.php`文件。 2. 在`index.php`文件的开头添加以下代码: ```php // 获取访问者的IP地址 $ip = $_SERVER['REMOTE_ADDR']; // 判断IP地址是否为巴西的IP段 $brazilIPs = [ '187.0.0.0/8', // 巴西IP段,根据实际情况添加更多IP段 // 添加其他巴西IP段 ]; $allowed = false; foreach ($brazilIPs as $brazilIP) { if (ipInRange($ip, $brazilIP)) { $allowed = true; break; } } // 如果IP地址不在巴西IP段内,则返回403 Forbidden 错误 if (!$allowed) { header('HTTP/1.1 403 Forbidden'); exit('403 Forbidden'); } /** * 判断IP地址是否在指定IP段内 * @param string $ip IP地址 * @param string $range IP段 * @return bool */ function ipInRange($ip, $range) { if (strpos($range, '/') == false) { $range .= '/32'; } list($rangeIP, $mask) = explode('/', $range, 2); $rangeIP = ip2long($rangeIP); $ip = ip2long($ip); $mask = ~((1 << (32 - $mask)) - 1); return ($ip & $mask) === ($rangeIP & $mask); } ``` 3. 在`$brazilIPs`数组中添加巴西的IP段,根据实际情况添加更多IP段。 4. 保存并上传修改后的`index.php`文件到服务器。 5. 现在,只有来自巴西的IP地址才能访问你的ThinkPHP项目,其他所有IP地址将被限制访问。 请注意,这种方法只是通过IP地址进行限制,并不能完全保证访问的安全性。如果需要更严格的访问控制和安全性,建议使用其他方法,如认证和授权。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值