PHP实现redis限制单ip、单用户的访问次数功能示例
程序员文章站
2023-11-14 12:12:16
本文实例讲述了php实现redis限制单ip、单用户的访问次数功能。分享给大家供大家参考,具体如下:
有时候我们需要限制一个api或页面访问的频率,例如单ip或单用户一分...
本文实例讲述了php实现redis限制单ip、单用户的访问次数功能。分享给大家供大家参考,具体如下:
有时候我们需要限制一个api或页面访问的频率,例如单ip或单用户一分钟之内只能访问多少次
类似于这样的需求很容易用redis来实现
<?php $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相关内容感兴趣的读者可查看本站专题:《php+redis数据库程序设计技巧总结》、《php面向对象程序设计入门教程》、《php基本语法入门教程》、《php数组(array)操作技巧大全》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家php程序设计有所帮助。