php限制ip访问次数 并发_PHP实现redis限制单ip、单用户的访问次数功能示例

本文实例讲述了PHP实现redis限制单ip、单用户的访问次数功能。分享给大家供大家参考,具体如下:

有时候我们需要限制一个api或页面访问的频率,例如单ip或单用户一分钟之内只能访问多少次

类似于这样的需求很容易用Redis来实现

$redis = new Redis();

$redis->connect('127.0.0.1', 6379);

$redis->auth("php001");

//这个key记录该ip的访问次数 也可改成用户id

//$key = 'userid_11100';

$key=get_real_ip();

//限制次数为5

$limit = 5;

$check = $redis->exists($key);

if($check){

$redis->incr($key);

$count = $redis->get($key);

if($count > 5){

exit('请求太频繁,请稍后再试!');

}

}else{

$redis->incr($key);

//限制时间为60秒

$redis->expire($key,60);

}

$count = $redis->get($key);

echo '第 '.$count.' 次请求';

//获取客户端真实ip地址

function get_real_ip(){

static $realip;

if(isset($_SERVER)){

if(isset($_SERVER['HTTP_X_FORWARDED_FOR'])){

$realip=$_SERVER['HTTP_X_FORWARDED_FOR'];

}else if(isset($_SERVER['HTTP_CLIENT_IP'])){

$realip=$_SERVER['HTTP_CLIENT_IP'];

}else{

$realip=$_SERVER['REMOTE_ADDR'];

}

}else{

if(getenv('HTTP_X_FORWARDED_FOR')){

$realip=getenv('HTTP_X_FORWARDED_FOR');

}else if(getenv('HTTP_CLIENT_IP')){

$realip=getenv('HTTP_CLIENT_IP');

}else{

$realip=getenv('REMOTE_ADDR');

}

}

return $realip;

}

?>

希望本文所述对大家PHP程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值