ThinkPHP5.1中表单令牌Token失效如何解决
这篇文章将为大家详细讲解有关ThinkPHP5.1中表单令牌Token失效如何解决,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
第一步:在Index控制器下创建生成Token的方法
之所以选择在Index控制器下创建,主要考虑在整个admin(后台)可以方便的引用该方法,不需要每次都根据控制器找寻相应的方法。也就是说,该方法其他控制器都可以引用!
<?php
namespaceapp\admin\controller;
usethink\Controller;
classIndexextendsValid{
//生成token函数
publicfunctiongetToken(){
$request=\think\facade\Request::instance();
echo$request->token();
}
}第二步:在Javascript中创建Ajax获取新令牌
由于后台生成新令牌的地址已经固定了,也就是:/admin/Index/,因此通过jQuery的Get方法容易获取该令牌!
//获取新Token并更新
functiongetNewToken(){
$.get("/admin/Index/getToken",function(data){
document.getElementById("__token__").value=data;
});
}第三步:在Html页面中创建隐藏域保存令牌
其实在ThinkPHP的表单示例代码中已经有了该代码。页面第一次加载时的令牌Token是随着页面分配的,后面的令牌就是通过Ajax获取的!
<!--隐藏区域-->
<inputtype="hidden"id="__token__"name="__token__"value="{$Request.token}"/>最后,我们就可以在javascript的相应提交表单的地方增加语句申请新令牌了!举例,下面的示例代码在提交后不管成功与否都申请了新的令牌。
/**
*Ajax动态更新数据并异步刷新页面
*@AuthorDuDongHua
*@DateTime2018-04-28T21:21:23+0800
*@param{对象}Button表单按钮对象
*@param{文本}Modal模块
*@param{文本}Controller控制器
*@param{文本}Action方法
*@param{文本}LocationAjax加载页面的位置id
*使用方法:表单对象不用提交的任何设置,提交假按钮<a>设置onclick即可
*注意:
*1.在javascript中拼接Thinkphp5的URL地址,不需要"{:url('"+Modal+"/"+Controller+"/"+Page+"')}方法
*只需要直接拼接地址即可,如:varMeURL='/'+Modal+'/'+Controller+'/'+Page;
*/
functionEditData(Button,Modal,Controller,Action,Location,Page){
//设置默认参数
varModal=arguments[1]?arguments[1]:"admin";//模块名
varController=arguments[2]?arguments[2]:"index";//控制器
varAction=arguments[3]?arguments[3]:"editData";//方法名
varLocation=arguments[4]?arguments[4]:"content";//Ajax加载页面的位置id
varPage=arguments[5]?arguments[5]:"index";//Ajax加载页面控制器中的方法
//生成本页面的url用于更新后异步刷新
varMeURL='/'+Modal+'/'+Controller+'/'+Page;
setLoaderIn(true);//打开加载图标
//异步请求数据
$.ajax({
url:'/'+Modal+'/'+Controller+'/'+Action,
type:'POST',
data:$(Button).closest("form").serialize(),//表单序列化
dataType:'json',
success:function(data){
//更新页面并提示
//window.location.reload();//当加载整个页面时有效但ajax更新时加载到主页
loadAjaxHTML(MeURL,Location);
showMsg(data.msg);
setLoaderIn(false);//关闭加载图标
getNewToken();//获取新Token
},
error:function(XMLHttpRequest,textStatus,errorThrown){
showMsg(XMLHttpRequest.status+""+XMLHttpRequest.readyState,textStatus,"red","#f60");
getNewToken();//获取新Token
}
});
}关于ThinkPHP5.1中表单令牌Token失效如何解决就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
推荐阅读
-
4个理由告诉你Java为何排行第一
本文由码农网 –单劼原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划!Java已经有20年的历史了,甚...
-
写给精明Java开发者的测试技巧
我们都会为我们的代码编写测试,不是吗?毫无疑问,我知道这个问题的答案可能会从“当然,但你知道怎样才能避免写测试吗?”到“必须...
-
Java 微服务框架 Redkale 入门介绍
Redkale功能Redkale虽然只有1.xM大小,但是麻雀虽小五脏俱全。既可作为服务器使用,也可当工具包使用。作为独立的工...
-
Java内存管理原理及内存区域详解
一、概述Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干不同的数据区域,这些区域都有各自的用途以及创建和销毁...
-
2015年Java开发岗位面试题归类
下面是我自己收集整理的Java岗位今天面经遇到的面试题,可以用它来好好准备面试。一、Java基础1.String...
-
Java 虚拟机类加载机制和字节码执行引擎
引言我们知道java代码编译后生成的是字节码,那虚拟机是如何加载这些class字节码文件的呢?加载之后又是如何进行方法调用的呢?...
-
Java常量池理解与总结
一.相关概念什么是常量用final修饰的成员变量表示常量,值一旦给定就无法改变!final修饰的变量有三种:静态...
-
Java 实现线程死锁
概述春节的时候去面试了一家公司,笔试题里面有一道是使用简单的代码实现线程的‘死锁’,当时没有想到这道题考的是Sync...
-
Java:过去、未来的互联网编程之王
Java对你而言是什么?一门你大学里学过的语言?一个IT行业的通用语言?你相信Java已经为下一次互联网爆炸做好了准备么?Java...
-
20个高级Java面试题汇总
本文由码农网 –小峰原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划!这是一个高级Java面试系列题中...
