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失效如何解决就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
目录
推荐阅读
0 条评论
本站已关闭游客评论,请登录或者注册后再评论吧~