-
在php中实现限流ip次数以及允许部分ip访问的代码示例
这篇文章给大家介绍了如何在php中实现限流ip次数以及允许部分ip访问,文中通过代码示例给大家介绍的非常详细,对大家的学习具有一定的参考价值,需要的朋友可以参考下
使用$_SERVER['REMOTE_ADDR']变量获取访问者的IP地址,然后将它与允许的IP地址进行比较。如果IP地址不在允许的列表中,你可以采取相应的行动,例如返回错误消息或重定向到其他页面。
结合IP访问限制和计数器来实现。以下是一个示例:
<?php
function restrictIPAccessWithRateLimit($allowedIPs, $limitTime = 60, $limitCount = 10) {
$visitorIP = $_SERVER['REMOTE_ADDR']; // 获取访问者的IP地址
$currentTime = time(); // 当前时间戳
// 检查IP地址是否在允许的列表中 *允许所有域名
if ($allowedIPs!='*'&&!in_array($visitorIP, $allowedIPs)) {
echo "Access denied!";
exit;
}
// 使用IP地址和当前时间戳生成唯一的计数器标识符
$counterKey = 'access_counter_' . $visitorIP;
// 开启Session
session_start();
// 从Session中获取计数器值和过期时间
$counter = isset($_SESSION[$counterKey]['value']) ? $_SESSION[$counterKey]['value'] : 0;
$expireTime = isset($_SESSION[$counterKey]['expireTime']) ? $_SESSION[$counterKey]['expireTime'] : 0;
// 检查过期时间是否已过或计数器值是否超过限制
if ($currentTime > $expireTime || $counter >= $limitCount) {
echo "Access limit exceeded!";
exit;
}
// 更新计数器值和过期时间
$counter++;
$expireTime = $currentTime + $limitTime;
// 保存更新后的计数器值和过期时间到Session
$_SESSION[$counterKey] = array(
'value' => $counter,
'expireTime' => $expireTime
);
}
// 使用示例
$allowedIPs = array('192.168.0.1', '10.0.0.1'); // 允许访问的IP地址列表
$limitTime = 60; // 限制时间(秒)
$limitCount = 10; // 限制计数
restrictIPAccessWithRateLimit($allowedIPs, $limitTime, $limitCount);
// 允许访问的代码...
在上面的示例中,我们创建了restrictIPAccessWithRateLimit方法,它结合了IP访问限制和访问频率限制。我们使用Session来保存计数器值和过期时间,并通过Session来跟踪每个IP地址的访问次数。
在使用示例中,我们指定了允许访问的IP地址列表、限制时间和限制计数,并调用restrictIPAccessWithRateLimit方法进行访问控制。如果访问被拒绝或访问频率超过限制,将返回相应的提示信息并终止脚本的执行。
请确保在实际使用中,按照你的需求和环境,对代码进行适当的修改和调整。
以上就是在php中实现限流ip次数以及允许部分ip访问的代码示例的详细内容,更多关于php限流ip次数及允许ip访问的资料请关注
原文链接:https://blog.csdn.net/weixin_39934453/article/details/135088685
栏目列表
最新更新
使用Java实现KMZ和KML数据的直接解析
Spring Boot最经典的20道面试题你都会了吗
Java中Instant的使用及转换
Spring中ClassPath指的是哪些地方
在SpringBoot项目中使用JetCache缓存的详细教
SpringBoot使用@Scheduled实现定时任务的并行
使用Spring事件监听机制实现跨模块调用的
详解SpringBoot如何让指定的Bean先加载
Spring实现资源的动态加载和卸载的方法小
使用Python发送电子邮件
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比