ThinkPHP 防止表單重復(fù)提交的方法
用戶提交表單以后,點擊瀏覽器后退按鈕返回表單頁面,這個時候瀏覽器會直接從緩存中取出頁面,因此token驗證一定是通不過的。
網(wǎng)上有許多種辦法可以繞過這個問題,比如用location.replace()方法來替換當(dāng)前歷史記錄,但是這樣仍然有瑕疵。極端的情況,若用戶在頁面間切換多次,那么多點幾次后退按鈕很可能又回到了上一個表單頁面。
解決辦法是在http頭中設(shè)置Cache-Control: no-cache, no-store。然而我嘗試了無論是在頁面head中添加 <meta http-equiv="Cache-Control" content="no-cache, no-store"> 還是在Action中輸出 header("Cache-control: no-cache, no-store") 都無效。

查找了很久,發(fā)現(xiàn)問題出在ThinkPHP的模板渲染機(jī)制上,打開 ThinkPHP/Lib/Think/Core/View.class.php 看第173行
header("Cache-control: private"); //支持頁面回跳 |
原來TP為了支持頁面回跳,強(qiáng)制在每個模板輸出之前都發(fā)送了一個Cache-control: private的頭,這可真是幫了倒忙了。
把這行注釋掉,刪除TP核心緩存,再試一次,發(fā)現(xiàn)HTTP響應(yīng)頭成功改變了

- TP5(thinkPHP5)框架基于ajax與后臺數(shù)據(jù)交互操作簡單示例
- thinkPHP5 ajax提交表單操作實例分析
- thinkPHP5框架實現(xiàn)基于ajax的分頁功能示例
- Thinkphp5框架ajax接口實現(xiàn)方法分析
- ThinkPHP5 通過ajax插入圖片并實時顯示(完整代碼)
- TP5(thinkPHP5)框架使用ajax實現(xiàn)與后臺數(shù)據(jù)交互的方法小結(jié)
- ThinkPHP5.1+Ajax實現(xiàn)的無刷新分頁功能示例
- ThinkPHP表單自動提交驗證實例教程
- ThinkPHP提交表單時默認(rèn)自動轉(zhuǎn)義的解決方法
- thinkphp3.2實現(xiàn)在線留言提交驗證碼功能
- ThinkPHP防止重復(fù)提交表單的方法實例分析
- thinkphp5 + ajax 使用formdata提交數(shù)據(jù)(包括文件上傳) 后臺返回json完整實例
相關(guān)文章
SQL server不支持utf8 php卻用utf8的矛盾問題解決方法
這篇文章主要介紹了SQL server不支持utf8 php卻用utf8的矛盾問題解決方法,需要的朋友可以參考下2020-03-03
php阿拉伯?dāng)?shù)字轉(zhuǎn)中文人民幣大寫
這篇文章主要介紹了php阿拉伯?dāng)?shù)字轉(zhuǎn)中文大寫金額,分享了兩種實現(xiàn)方法,感興趣的小伙伴們可以參考一下2015-12-12
我的php學(xué)習(xí)筆記(畢業(yè)設(shè)計)
不單是為了做畢業(yè)設(shè)計,其實更多的是想學(xué)會它,能弄弄網(wǎng)站什么的,只要能做好,我覺得就是可以去學(xué),可以去嘗試的2012-02-02
php中通過DirectoryIterator刪除整個目錄的方法
這篇文章主要介紹了php中通過DirectoryIterator刪除整個目錄的方法,實例分析了php通過DirectoryIterator類操作目錄的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03
解析百度搜索結(jié)果link?url=參數(shù)分析 (全)
自從9月后百度和360開戰(zhàn)的結(jié)果就是 百度搜索結(jié)果的網(wǎng)址改變了,變成link?url=………這樣的重定向格式了??吹竭@樣的不友好的URL真有破解的沖動。于是今天開始試試破解它2012-10-10
php通過ajax實現(xiàn)雙擊table修改內(nèi)容
這篇文章主要介紹了php通過如何ajax實現(xiàn)雙擊table修改內(nèi),需要的朋友可以參考下2014-04-04

