新聞中心
以訪(fǎng)問(wèn)控制的配額管理來(lái)講,其主要是通過(guò)一定的策略來(lái)限制一定時(shí)間段內(nèi),用戶(hù)的訪(fǎng)問(wèn)個(gè)數(shù),防止惡意的訪(fǎng)問(wèn)影響到系統(tǒng)的正常服務(wù),下面就來(lái)講解一下如何使用Redis實(shí)現(xiàn)訪(fǎng)問(wèn)控制的配額管理。

基本思路是使用計(jì)數(shù)器的技術(shù)來(lái)對(duì)Redis的訪(fǎng)問(wèn)頻率進(jìn)行限制,使用一個(gè)長(zhǎng)度為N的哈希表來(lái)存儲(chǔ)每個(gè)客戶(hù)端的計(jì)數(shù)器,當(dāng)客戶(hù)端發(fā)起請(qǐng)求時(shí),會(huì)先在哈希表中查找客戶(hù)端的計(jì)數(shù)器,如果該客戶(hù)端的計(jì)數(shù)器小于N,則該請(qǐng)求允許,該客戶(hù)端的計(jì)數(shù)器會(huì)+1,如果計(jì)數(shù)器已經(jīng)大于等于N,則表明客戶(hù)端在一定時(shí)間內(nèi)已經(jīng)訪(fǎng)問(wèn)過(guò)該服務(wù),則阻止該請(qǐng)求,告知用戶(hù)超過(guò)了訪(fǎng)問(wèn)頻率,不能訪(fǎng)問(wèn)。
具體實(shí)現(xiàn)可以通過(guò)在Redis中定義一個(gè)鍵,該鍵是一個(gè)哈希表,其中的每個(gè)域表示一個(gè)客戶(hù)端的地址,值表示該客戶(hù)端的計(jì)數(shù)器(具體計(jì)數(shù)器的實(shí)現(xiàn)可以使用Redis的incr命令,也可以是Redis的其它指令),每當(dāng)客戶(hù)端發(fā)起請(qǐng)求時(shí),先判斷該客戶(hù)端的計(jì)數(shù)器是否已經(jīng)達(dá)到了訪(fǎng)問(wèn)控制的額度:
// 在Redis客戶(hù)端連接
$redis = new Redis();
$redis->connect(“127.0.0.1”);
// 標(biāo)志客戶(hù)端地址
$client_address = $_SERVER[“REMOTE_ADDR”];
// 從計(jì)數(shù)器中獲取該客戶(hù)端的計(jì)數(shù)
$count = $redis->hGet(“counter”, $client_address);
// 判斷計(jì)數(shù)器的值是否達(dá)到閥值
if ($count >= N){
// 如果計(jì)數(shù)器的值達(dá)到閥值,則返回錯(cuò)誤提示,拒絕訪(fǎng)問(wèn)
echo “Error: Access Denied”;
} else {
// 如果計(jì)數(shù)器的值小于閥值,則遞增計(jì)數(shù)器
$redis->hIncrBy(“counter”, $client_address, 1);
// 其它代碼
…
}
以上使用Redis進(jìn)行訪(fǎng)問(wèn)控制的配額管理,可以有效的驗(yàn)證用戶(hù)的訪(fǎng)問(wèn)頻率,將一定時(shí)間段內(nèi)惡意訪(fǎng)問(wèn)過(guò)多的用戶(hù)限制訪(fǎng)問(wèn)。
成都網(wǎng)站營(yíng)銷(xiāo)推廣找創(chuàng)新互聯(lián),全國(guó)分站站群網(wǎng)站搭建更好做SEO營(yíng)銷(xiāo)。
創(chuàng)新互聯(lián)(www.cdcxhl.com)四川成都IDC基礎(chǔ)服務(wù)商,價(jià)格厚道。提供成都服務(wù)器托管租用、綿陽(yáng)服務(wù)器租用托管、重慶服務(wù)器托管租用、貴陽(yáng)服務(wù)器機(jī)房服務(wù)器托管租用。
本文名稱(chēng):使用Redis實(shí)現(xiàn)訪(fǎng)問(wèn)控制的配額管理(redis配額)
轉(zhuǎn)載源于:http://www.5511xx.com/article/cogjiii.html


咨詢(xún)
建站咨詢(xún)
