表單令牌驗(yàn)證相關(guān)的配置參數(shù)有:
'TOKEN_ON'=>true, // 是否開(kāi)啟令牌驗(yàn)證 'TOKEN_NAME'=>'__hash__', // 令牌驗(yàn)證的表單隱藏字段名稱(chēng) 'TOKEN_T " /> 日产福利视频在线观看,国产精品v日韩精品v欧美精品网站 ,精品亚洲porn

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

ThinkPHP令牌驗(yàn)證實(shí)例

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

'TOKEN_ON'=>true, // 是否開(kāi)啟令牌驗(yàn)證 'TOKEN_NAME'=>'__hash__', // 令牌驗(yàn)證的表單隱藏字段名稱(chēng) 'TOKEN_TYPE'=>'md5', //令牌哈希驗(yàn)證規(guī)則 默認(rèn)為MD5 

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

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

如果頁(yè)面中存在多個(gè)表單,建議添加__TOKEN__標(biāo)識(shí),并確保只有一個(gè)表單需要令牌驗(yàn)證。

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

$User = M("User"); // 實(shí)例化User對(duì)象 // 手動(dòng)進(jìn)行令牌驗(yàn)證 if (!$User->autoCheckToken($_POST)){ // 令牌驗(yàn)證錯(cuò)誤 } 

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

protected function templateContentReplace($content) { // 系統(tǒng)默認(rèn)的特殊變量替換 $replace = array( '../Public' => APP_PUBLIC_PATH,// 項(xiàng)目公共目錄 '__PUBLIC__' => WEB_PUBLIC_PATH,// 站點(diǎn)公共目錄 '__TMPL__' => APP_TMPL_PATH, // 項(xiàng)目模板目錄 '__ROOT__' => __ROOT__, // 當(dāng)前網(wǎng)站地址 '__APP__' => __APP__, // 當(dāng)前項(xiàng)目地址 '__UPLOAD__' => __ROOT__.'/Uploads', '__ACTION__' => __ACTION__, // 當(dāng)前操作地址 '__SELF__' => __SELF__, // 當(dāng)前頁(yè)面地址 '__URL__' => __URL__, '__INFO__' => __INFO__, ); if(defined('GROUP_NAME')) { $replace['__GROUP__'] = __GROUP__;// 當(dāng)前項(xiàng)目地址 } if(C('TOKEN_ON')) { if(strpos($content,'{__TOKEN__}')) { // 指定表單令牌隱藏域位置 $replace['{__TOKEN__}'] = $this->buildFormToken(); }elseif(strpos($content,'{__NOTOKEN__}')){ // 標(biāo)記為不需要令牌驗(yàn)證 $replace['{__NOTOKEN__}'] = ''; }elseif(preg_match('/<//form(/s*)>/is',$content,$match)) { // 智能生成表單令牌隱藏域 $replace[$match[0]] = $this->buildFormToken().$match[0]; } } // 允許用戶(hù)自定義模板的字符串替換 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'))是對(duì)令牌驗(yàn)證的開(kāi)啟狀態(tài)進(jìn)行判斷,若開(kāi)啟則調(diào)用buildFormToken()方法,$_SESSION[$tokenName] = $tokenValue; 其實(shí)就是給$_SESSION['__hash__']賦值。如果不想進(jìn)行令牌驗(yàn)證,只要在頁(yè)面的</form>之前加入{__NOTOKEN__}就行了,它會(huì)被函數(shù)替換成空。

在Thinkphp的Model.class.php類(lèi)里定義了令牌的驗(yàn)證函數(shù)

// 表單令牌驗(yàn)證 if(C('TOKEN_ON') && !$this->autoCheckToken($data)) { $this->error = L('_TOKEN_ERROR_'); return false; } // 自動(dòng)表單令牌驗(yàn)證 public function autoCheckToken($data) { $name = C('TOKEN_NAME'); if(isset($_SESSION[$name])) { // 當(dāng)前需要令牌驗(yàn)證 if(empty($data[$name]) || $_SESSION[$name] != $data[$name]) { // 非法提交 return false; } // 驗(yàn)證完成銷(xiāo)毀session unset($_SESSION[$name]); } return true; }

php技術(shù)ThinkPHP令牌驗(yàn)證實(shí)例,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 得荣县| 斗六市| 陈巴尔虎旗| 无锡市| 英德市| 松潘县| 广安市| 米泉市| 枝江市| 大悟县| 朔州市| 佛坪县| 濮阳县| 泸西县| 余江县| 策勒县| 都昌县| 孟连| 韶关市| 金寨县| 苍梧县| 日喀则市| 天门市| 湘潭市| 稻城县| 甘洛县| 昭平县| 东兴市| 平远县| 沛县| 康保县| 翁源县| 开原市| 额敏县| 漳平市| 旬邑县| 宁德市| 衡东县| 泽库县| 沁源县| 沾化县|