表單令牌驗證相關的配置參數有:
'TOKEN_ON'=>true, // 是否開啟令牌驗證 'TOKEN_NAME'=>'__hash__', // 令牌驗證的表單隱藏字段名稱 'TOKEN_T " /> 乳女教师欲乱动漫无修版动画,欧美国产影院,在线免费观看国产

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

ThinkPHP令牌驗證實例

Thinkphp內置了表單令牌驗證功能,可以有效防止表單的遠程提交等安全防護。
表單令牌驗證相關的配置參數有:

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

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

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

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

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

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

在Thinkphp框架的View.class.php里定義了一個公共的模板替換函數

protected function templateContentReplace($content) { // 系統默認的特殊變量替換 $replace = array( '../Public' => APP_PUBLIC_PATH,// 項目公共目錄 '__PUBLIC__' => WEB_PUBLIC_PATH,// 站點公共目錄 '__TMPL__' => APP_TMPL_PATH, // 項目模板目錄 '__ROOT__' => __ROOT__, // 當前網站地址 '__APP__' => __APP__, // 當前項目地址 '__UPLOAD__' => __ROOT__.'/Uploads', '__ACTION__' => __ACTION__, // 當前操作地址 '__SELF__' => __SELF__, // 當前頁面地址 '__URL__' => __URL__, '__INFO__' => __INFO__, ); if(defined('GROUP_NAME')) { $replace['__GROUP__'] = __GROUP__;// 當前項目地址 } 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'))是對令牌驗證的開啟狀態進行判斷,若開啟則調用buildFormToken()方法,$_SESSION[$tokenName] = $tokenValue; 其實就是給$_SESSION['__hash__']賦值。如果不想進行令牌驗證,只要在頁面的</form>之前加入{__NOTOKEN__}就行了,它會被函數替換成空。

在Thinkphp的Model.class.php類里定義了令牌的驗證函數

// 表單令牌驗證 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])) { // 當前需要令牌驗證 if(empty($data[$name]) || $_SESSION[$name] != $data[$name]) { // 非法提交 return false; } // 驗證完成銷毀session unset($_SESSION[$name]); } return true; }

php技術ThinkPHP令牌驗證實例,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲三级在线观看 | 欧洲美女人 一级毛片 | 免费高清在线影片一区 | 久久人妻无码毛片A片麻豆 久久人妻熟女中文字幕AV蜜芽 | 捆绑白丝粉色JK震动捧喷白浆 | 九九热视频 这里有精品 | 亚洲精品蜜桃AV久久久 | 最近的中文字幕免费完整 | 在线超碰免费视频观看 | 国产午夜一级淫片 | 日本枯瘦娇小 | 妹妹好色网 | 女神被调教成了精盆 | 精品亚洲视频在线观看 | 国产日韩亚洲精品视频 | 一品道门在线视频高清完整版 | 久久久久青草大香线综合精品 | 伊人久久大香线蕉综合99 | 在线视频 中文字幕 | 99手机在线视频 | 日本大片免a费观看视频 | 欧美午夜精品一区区电影 | 超碰国产亚洲人人 | 精品水蜜桃久久久久久久 | 国产精品白浆精子流水合集 | 亚洲人人为我我为人人 | 精品久久香蕉国产线看观看麻豆 | 精品国产免费人成视频 | 拍戏被CAO翻了H | 大咪咪dvd | 国产激情视频在线播放 | 日本亚欧热亚洲乱色视频 | ca88亚洲城娱乐| 国产在线视频一区二区不卡 | 九九精品视频在线播放 | 国产在线高清视频 | 亚洲AV永久无码精品老司机蜜桃 | 一个人HD高清在线观看免费视频 | 97视频免费在线观看 | 天天夜夜草草久久亚洲香蕉 | 麻豆国产96在线日韩麻豆 |