ThinkPHP5.1表單令牌Token失效問(wèn)題的解決
前言
ThinkPHP出于安全的考慮增加了表單令牌Token,由于通過(guò)Ajax異步更新數(shù)據(jù)僅僅部分頁(yè)面刷新數(shù)據(jù),就導(dǎo)致了令牌Token不能得到更新,緊接著的第二次新建或更新數(shù)據(jù)(提交表單時(shí))失敗——不能通過(guò)令牌的驗(yàn)證。
當(dāng)然了,最簡(jiǎn)單的辦法就是刷新整個(gè)頁(yè)面,就導(dǎo)致了異步刷新的無(wú)意義!在網(wǎng)上搜尋了很多,有好幾種方法;看完覺(jué)得有一個(gè)最好:
Ajax異步動(dòng)態(tài)請(qǐng)求創(chuàng)建新令牌并更新到本地
主要思路:在每次發(fā)送表單結(jié)束后(不管成功與否)通過(guò)Ajax異步請(qǐng)求一個(gè)新的表單令牌并保存到表單隱藏域中,下次提交表單就使用新的表單令牌去通過(guò)。
最終的效果如下:

V2.5.0.png
主要分成三步:
第一步:在Index控制器下創(chuàng)建生成Token的方法
之所以選擇在Index控制器下創(chuàng)建,主要考慮在整個(gè)admin(后臺(tái))可以方便的引用該方法,不需要每次都根據(jù)控制器找尋相應(yīng)的方法。也就是說(shuō),該方法其他控制器都可以引用!
<?php
namespace app\admin\controller;
use think\Controller;
class Index extends Valid {
// 生成token函數(shù)
public function getToken() {
$request = \think\facade\Request::instance();
echo $request->token();
}
}
第二步:在Javascript中創(chuàng)建Ajax獲取新令牌
由于后臺(tái)生成新令牌的地址已經(jīng)固定了,也就是:
/admin/Index/,因此通過(guò)jQuery的Get方法容易獲取該令牌!
// 獲取新Token并更新
function getNewToken() {
$.get("/admin/Index/getToken", function(data) {
document.getElementById("__token__").value = data;
});
}
第三步:在Html頁(yè)面中創(chuàng)建隱藏域保存令牌
其實(shí)在ThinkPHP的表單示例代碼中已經(jīng)有了該代碼。頁(yè)面第一次加載時(shí)的令牌Token是隨著頁(yè)面分配的,后面的令牌就是通過(guò)Ajax獲取的!
<!-- 隱藏區(qū)域 -->
<input type="hidden" id="__token__" name="__token__" value="{$Request.token}" />
最后,我們就可以在javascript的相應(yīng)提交表單的地方增加語(yǔ)句申請(qǐng)新令牌了!舉例,下面的示例代碼在提交后不管成功與否都申請(qǐng)了新的令牌。
/**
* Ajax動(dòng)態(tài)更新數(shù)據(jù)并異步刷新頁(yè)面
* @Author DuDongHua
* @DateTime 2018-04-28T21:21:23+0800
* @param {對(duì)象} Button 表單按鈕對(duì)象
* @param {文本} Modal 模塊
* @param {文本} Controller 控制器
* @param {文本} Action 方法
* @param {文本} Location Ajax加載頁(yè)面的位置id
* 使用方法:表單對(duì)象不用提交的任何設(shè)置,提交假按鈕<a>設(shè)置onclick即可
* 注意:
* 1. 在javascript中拼接Thinkphp5的URL地址,不需要"{:url('" + Modal + "/" + Controller + "/" + Page + "')}方法
* 只需要直接拼接地址即可,如:var MeURL = '/'+Modal+'/'+Controller+'/'+Page;
*/
function EditData(Button,Modal,Controller,Action,Location,Page){
// 設(shè)置默認(rèn)參數(shù)
var Modal = arguments[1] ? arguments[1] : "admin"; // 模塊名
var Controller = arguments[2] ? arguments[2] : "index"; // 控制器
var Action = arguments[3] ? arguments[3] : "editData"; // 方法名
var Location = arguments[4] ? arguments[4] : "content"; // Ajax加載頁(yè)面的位置id
var Page = arguments[5] ? arguments[5] : "index"; // Ajax加載頁(yè)面控制器中的方法
// 生成本頁(yè)面的url用于更新后異步刷新
var MeURL = '/'+Modal+'/'+Controller+'/'+Page;
setLoaderIn(true); //打開(kāi)加載圖標(biāo)
// 異步請(qǐng)求數(shù)據(jù)
$.ajax({
url: '/'+Modal+'/'+Controller+'/'+Action,
type: 'POST',
data: $(Button).closest("form").serialize(), //表單序列化
dataType: 'json',
success: function(data){
// 更新頁(yè)面并提示
// window.location.reload(); //當(dāng)加載整個(gè)頁(yè)面時(shí)有效但ajax更新時(shí)加載到主頁(yè)
loadAjaxHTML(MeURL,Location);
showMsg(data.msg);
setLoaderIn(false); //關(guān)閉加載圖標(biāo)
getNewToken(); // 獲取新Token
},
error:function(XMLHttpRequest, textStatus, errorThrown){
showMsg(XMLHttpRequest.status+" "+XMLHttpRequest.readyState,textStatus,"red","#f60");
getNewToken(); // 獲取新Token
}
});
}
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
php利用單例模式實(shí)現(xiàn)日志處理類庫(kù)
該日志類利用單例模式,節(jié)省資源。自行判斷文件大小,超出指定大小則按序自行創(chuàng)建文件。2014-02-02
PHP 使用 Imagick 裁切/生成縮略圖/添加水印自動(dòng)檢測(cè)和處理 GIF
這篇文章主要介紹了PHP 使用 Imagick 裁切/生成縮略圖/添加水印自動(dòng)檢測(cè)和處理 GIF的相關(guān)資料,需要的朋友可以參考下2016-02-02
使用PHP處理數(shù)據(jù)庫(kù)數(shù)據(jù)如何將數(shù)據(jù)返回客戶端并顯示當(dāng)前狀態(tài)
這篇文章給大家介紹使用php處理大量數(shù)據(jù),每處理一個(gè)數(shù)據(jù)返回客戶端顯示當(dāng)前狀態(tài)的方法,對(duì)PHP處理數(shù)據(jù)庫(kù)數(shù)據(jù)返回客戶端并顯示當(dāng)前狀態(tài)的相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-02-02
使用Appcan客戶端自動(dòng)更新PHP版本號(hào)(全)
在項(xiàng)目開(kāi)發(fā)過(guò)程中遇到app端自動(dòng)更新,查閱了相關(guān)資料然后把Appcan客戶端自動(dòng)更新PHP版本號(hào)的方法整理出來(lái),有需要的小伙伴可以來(lái)參考下2015-07-07
php安裝擴(kuò)展mysqli的實(shí)現(xiàn)步驟及報(bào)錯(cuò)解決辦法
這篇文章主要介紹了 php安裝擴(kuò)展mysqli的實(shí)現(xiàn)步驟及報(bào)錯(cuò)解決辦法的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下2017-09-09
Laravel 創(chuàng)建可以傳遞參數(shù) Console服務(wù)的例子
今天小編就為大家分享一篇Laravel 創(chuàng)建可以傳遞參數(shù) Console服務(wù)的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10

