本文實(shí)例講述了PHP實(shí)現(xiàn)redis限制單ip、單用戶的訪問(wèn)次數(shù)功能。分享給大家供大家參考,具體如下:
有時(shí)候我們需要限制一個(gè)api或頁(yè)面訪問(wèn)的頻率,例如單ip或單用戶一分鐘之內(nèi)只能訪問(wèn)多少次
類似于這樣的需求很容易用Redis來(lái)實(shí)現(xiàn)
?php
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis->auth("php001");
//這個(gè)key記錄該ip的訪問(wèn)次數(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('請(qǐng)求太頻繁,請(qǐng)稍后再試!');
}
}else{
$redis->incr($key);
//限制時(shí)間為60秒
$redis->expire($key,60);
}
$count = $redis->get($key);
echo '第 '.$count.' 次請(qǐng)求';
//獲取客戶端真實(shí)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;
}
?>
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php+redis數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP基本語(yǔ)法入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- php 使用redis鎖限制并發(fā)訪問(wèn)類示例
- 在Redis數(shù)據(jù)庫(kù)中實(shí)現(xiàn)分布式速率限制的方法
- Redis實(shí)戰(zhàn)記錄之限制操作頻率