php限制ip访问次数 并发_PHP实现redis限制单ip、单用户的访问次数功能示例
本文實例講述了PHP實現(xiàn)redis限制單ip、單用戶的訪問次數(shù)功能。分享給大家供大家參考,具體如下:
有時候我們需要限制一個api或頁面訪問的頻率,例如單ip或單用戶一分鐘之內(nèi)只能訪問多少次
類似于這樣的需求很容易用Redis來實現(xiàn)
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis->auth("php001");
//這個key記錄該ip的訪問次數(shù) 也可改成用戶id
//$key = 'userid_11100';
$key=get_real_ip();
//限制次數(shù)為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程序設(shè)計有所幫助。
總結(jié)
以上是生活随笔為你收集整理的php限制ip访问次数 并发_PHP实现redis限制单ip、单用户的访问次数功能示例的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 汇编大小写转换问题
- 下一篇: php javascript 不执行,j