表單令牌可以放置重復提交,同時對機器人有一定的攔截作用,在 phpGrace 的支持下(利用 cookie),實現這樣的功能是非常簡單的,函數說明:
**1、setToken() 設置token**
在表單中使用隱藏域設置令牌,如:
~~~
<form?action=""?method="post">
????<input?type="text"?name="name"?/>
????<input?type="hidden"?name="token"?value="<?php?echo?setToken();?>"?/>
????<input?type="submit"?value="提交"/>
</form>
~~~
**2、getToken 獲取令牌的值**
在控制器內獲取表單提交信息,并校驗令牌,如:
~~~
<?php
class?indexController?extends?grace{
????public?function?index(){
????????if(PG_POST){
????????????$token?=?getToken();
????????????echo?"系統記錄的?token:{$token}<br?/>";
????????????echo?"POST數據中的?token:{$_POST['__token__']}<br?/>";
????????????if($token?==?$_POST['__token__']){
????????????????echo?'ok';
????????????}else{
????????????????echo?'token?錯誤';
????????????}
????????}
????}
}
~~~
**說明:**
getToken() 獲取token 后會注銷 cookie 中記錄的 token,只能獲取一次哦 ?^\_^
**3、數據驗證過程中自動驗證token**
3.1 遵循規則:表單內隱藏域的名稱為:“\_\_token\_\_”
~~~
<input?type="hidden"?name="__token__"?value="<?php?echo?setToken();?>"?/>
~~~
3.2 在進行數據驗證是設置驗證token,如:
~~~
<?php
class?indexController?extends?grace{
????public?function?index(){
????????if(PG_POST){
????????????$checkRules?=?array(
????????????????'name'??=>?array('string',?'2,10',?'姓名應為?2?-?10?字符')
????????????);
????????????//第三個參數為可選參數,設置為true時自動檢查?Token
????????????$checker?=?new?phpGrace\tools\dataChecker($_POST,?$checkRules,?true);
????????????$res?=?$checker->check();
????????????if($res){
????????????????echo?'驗證通過';
????????????}else{
????????????????echo?$checker->error;
????????????}
????????}
????}
}
~~~
- 序言
- 環境需求
- 目錄結構&命名規則
- 初始化
- 第一章 控制器與路由
- 1.1 創建控制器
- 1.2 基礎控制器
- 1.3 url 解析規則
- 第二章 數據與模型
- 1.1 數據庫配置
- 1.2 獲取數據庫操作對象
- 1.3 數據庫操作(CRUD)
- 1.4 數據分頁詳解
- 1.5 phpGrace事務處理
- 1.6 數據驗證
- 1.7 表單令牌
- 1.8 全局模型創建與調用
- 第三章 視圖
- 1.1 創建視圖文件
- 1.2 視圖調用及引用
- 1.3 視圖文件路徑模式
- 第四章 會話機制
- 1.1 cookie 操作
- 1.2 文件型 SESSION
- 1.3 memcache形式的 SESSION
- 1.4 redis 形式的 SESSION
- 第五章 緩存機制
- 1.1 緩存的概述和配置
- 1.2 文件型緩存
- 1.3 memcache 形式的緩存
- 1.4 redis 形式的緩存
- 第六章 配置、常量、語言
- 1.1 全局配置、分組配置
- 1.2 預定義常量
- 1.2 語言包使用說明
- 第七章 工具大全
- 1.1 函數小工具
- 1.2 函數工具庫
- 第八章 安全與擴展
- 1.1 框架部署安全
- 1.2 phpGrace 安全概述
- 1.3 phpGrace 擴展說明
- 實戰項目(內容管理系統)
- 前端實戰graceui
- 項目API接口實戰