首頁 > 後端開發 > php教程 > PHP限制頻繁請求

PHP限制頻繁請求

WBOY
發布: 2016-07-29 09:00:55
原創
3264 人瀏覽過
<?php header("Content-Type:text/html; charset=utf-8");
 

include_once("libs/RSA.class.php");
/**
 * 在线高频频繁提交解决方案
 * @author 周阳<305846826@qq.com>
 * @link http://www.jieone.com/
 */
class Token extends RSA{
	/**
	 * 客户端唯一ID
	 */
	private $date=0;
	
	private $clientID="abccccc";
	/**
	 * 系统access_token,即要保存于客户端的数据
	 */
	private function sys_access_token(){
		$array=array(
				'clientID'=>$this->clientID,
				'date'=>$this->date
				);
		$sys_access_token = json_encode($array);
		//RSA公钥加密
		return $this->public_encrypt($sys_access_token);
	}
	/**
	 * 保存access_token
	 */
	public function get_access_token(){
		
		 if(empty($_COOKIE['access_token'])){
			 $this->date=time()-100;
			return $this->sys_access_token(); 
		 }
		 return $_COOKIE['access_token'];
	}
	/**
	 * 保存access_token
	 */
	private function save_access_token(){
		
		setcookie("access_token",$this->sys_access_token());	
	}
	
	public function check(){
		
		$access_token=$this->get_access_token();
		
		//RSA私钥解密
		$access_token = $this->private_decrypt($access_token);
		
		//信息已被非法篡改
		if(empty($access_token)){
			return false;
		}
		
		$object=json_decode($access_token);

		//2秒只能ajax请求一次,可修改
		if ($object->date + 2 > time()){
			return false;
		}
		//保存access_token
		$this->date=time();
		$this->save_access_token();
		return true;	
	}
		
}

echo '<br><br><br><br><br><br><center><h1>频繁刷新试试</h1></center><br>';

$Token=new Token();
if(!$Token->check()){
	echo '<center><h2 style=" color:red">您请求过快,请稍后再试</h2></center><br><br><br>';
	exit();
}
echo '<center><h2 style=" color:green">访问正常</h2></center><br><br><br>';

echo "您当前access_token:".$Token->get_access_token();
登入後複製

PHP限制頻繁請求

以上就介紹了PHP限制頻繁要求,包括了方面的內容,希望對PHP教程有興趣的朋友有所幫助。

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板