欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

如何實現(xiàn)ThinkPHP令牌驗證-創(chuàng)新互聯(lián)

這篇文章主要講解了“如何實現(xiàn)ThinkPHP令牌驗證”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“如何實現(xiàn)ThinkPHP令牌驗證”吧!

10年積累的成都做網(wǎng)站、網(wǎng)站設(shè)計、外貿(mào)營銷網(wǎng)站建設(shè)經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認識你,你也不認識我。但先網(wǎng)站制作后付款的網(wǎng)站建設(shè)流程,更有安居免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

ThinkPHP內(nèi)置了表單令牌驗證功能,可以有效防止表單的遠程提交等安全防護。
表單令牌驗證相關(guān)的配置參數(shù)有:


'TOKEN_ON'=>true, // 是否開啟令牌驗證 
'TOKEN_NAME'=>'__hash__', // 令牌驗證的表單隱藏字段名稱 
'TOKEN_TYPE'=>'md5', //令牌哈希驗證規(guī)則 默認為MD5

如果開啟表單令牌驗證功能,系統(tǒng)會自動在帶有表單的模板文件里面自動生成以TOKEN_NAME為名稱的隱藏域,其值則是TOKEN_TYPE方式生成的哈希字符串,用于實現(xiàn)表單的自動令牌驗證。

自動生成的隱藏域位于表單Form結(jié)束標志之前,如果希望自己控制隱藏域的位置,可以手動在表單頁面添加__TOKEN__ 標識,系統(tǒng)會在輸出模板的時候自動替換。如果在開啟表單令牌驗證的情況下,個別表單不需要使用令牌驗證功能,可以在表單頁面添加__NOTOKEN__,則系統(tǒng)會忽略當(dāng)前表單的令牌驗證。

如果頁面中存在多個表單,建議添加__TOKEN__標識,并確保只有一個表單需要令牌驗證。

模型類在創(chuàng)建數(shù)據(jù)對象的同時會自動進行表單令牌驗證操作,如果你沒有使用create方法創(chuàng)建數(shù)據(jù)對象的話,則需要手動調(diào)用模型的autoCheckToken方法進行表單令牌驗證。如果返回false,則表示表單令牌驗證錯誤。例如:



$User = M("User"); // 實例化User對象 
// 手動進行令牌驗證 
if (!$User->autoCheckToken($_POST)){ 
// 令牌驗證錯誤 
}

在ThinkPHP框架的View.class.php里定義了一個公共的模板替換函數(shù)


protected function templateContentReplace($content) {
 // 系統(tǒng)默認的特殊變量替換
 $replace = array(
 '../Public' => APP_PUBLIC_PATH,// 項目公共目錄
 '__PUBLIC__' => WEB_PUBLIC_PATH,// 站點公共目錄
 '__TMPL__' => APP_TMPL_PATH, // 項目模板目錄
 '__ROOT__' => __ROOT__, // 當(dāng)前網(wǎng)站地址
 '__APP__' => __APP__, // 當(dāng)前項目地址
 '__UPLOAD__' => __ROOT__.'/Uploads',
 '__ACTION__' => __ACTION__, // 當(dāng)前操作地址
 '__SELF__' => __SELF__, // 當(dāng)前頁面地址
 '__URL__' => __URL__,
 '__INFO__' => __INFO__,
 );
 if(defined('GROUP_NAME'))
 {
 $replace['__GROUP__'] = __GROUP__;// 當(dāng)前項目地址
 }
 if(C('TOKEN_ON')) {
 if(strpos($content,'{__TOKEN__}')) {
 // 指定表單令牌隱藏域位置
 $replace['{__TOKEN__}'] = $this->buildFormToken();
 }elseif(strpos($content,'{__NOTOKEN__}')){
 // 標記為不需要令牌驗證
 $replace['{__NOTOKEN__}'] = '';
 }elseif(preg_match('/<\/form(\s*)>/is',$content,$match)) {
 // 智能生成表單令牌隱藏域
 $replace[$match[0]] = $this->buildFormToken().$match[0];
 }
 }
 // 允許用戶自定義模板的字符串替換
 if(is_array(C('TMPL_PARSE_STRING')) )
 $replace = array_merge($replace,C('TMPL_PARSE_STRING'));
 $content = str_replace(array_keys($replace),array_values($replace),$content);
 return $content;
 }

上面的if(C('TOKEN_ON'))是對令牌驗證的開啟狀態(tài)進行判斷,若開啟則調(diào)用buildFormToken()方法,$_SESSION[$tokenName] = $tokenValue; 其實就是給$_SESSION['__hash__']賦值。如果不想進行令牌驗證,只要在頁面的</form>之前加入{__NOTOKEN__}就行了,它會被函數(shù)替換成空。

在ThinkPHP的Model.class.php類里定義了令牌的驗證函數(shù)


// 表單令牌驗證
 if(C('TOKEN_ON') && !$this->autoCheckToken($data)) {
 $this->error = L('_TOKEN_ERROR_');
 return false;
 }

 // 自動表單令牌驗證
 public function autoCheckToken($data) {
 $name = C('TOKEN_NAME');
 if(isset($_SESSION[$name])) {
 // 當(dāng)前需要令牌驗證
 if(empty($data[$name]) || $_SESSION[$name] != $data[$name]) {
 // 非法提交
 return false;
 }
 // 驗證完成銷毀session
 unset($_SESSION[$name]);
 }
 return true;
 }

感謝各位的閱讀,以上就是“如何實現(xiàn)ThinkPHP令牌驗證”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對如何實現(xiàn)ThinkPHP令牌驗證這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

新聞名稱:如何實現(xiàn)ThinkPHP令牌驗證-創(chuàng)新互聯(lián)
地址分享:http://chinadenli.net/article42/edshc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站面包屑導(dǎo)航網(wǎng)站營銷網(wǎng)頁設(shè)計公司App開發(fā)關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司