首页 > 作文

页面防重复提交方法总结

更新时间:2023-04-07 05:40:23 阅读: 评论:0

有时候我们的程序执行比较慢,而且我们页面也不怎么友好,没什么提示信息。操作人员以为没有点击提交按钮,就会再一次点击提交。这会导致很多问题出现。下面介绍三种防重复提交的方法。

1、提交按钮置disabled

当用户提交后,立即把按钮置为不可用状态。这种用js来实现。

提交前

$(“#submit”).attr(‘disabled’,’true’);

$(“#submit”).val(“正在提交,请稍等”);

…………………………………………………………………………

执行后,把按钮置为原来状态

$(‘#submit ‘).removeattr(‘disabled&教师节快乐#8217;);

$(“#submit “).val(“确定提交”);

2、过期时间法

思路:当用户提交按钮后生成一个token(每次业务提交token 为唯一值)存入ssion,并设置过期时间。当用户再此提交时,检测token是否一致且是否过期,若一致且没有过期,则认为提交了二次。当程序执行出错的时候,则需要清除存入ssion的值。见下面程序

function checkrepeatsubmit($uniqueid = ”, $expire = 30) {

$uniqueid = empty($uniqueid) ? yii::app()->ur->id . yii::app()->ur->name . yii::app()->ur->mihome : $uniqueid;

$童年的好词好句token = md5(“wms_check_repeat” . $uniqueid);

$time = time();

if (ist($_ssion[‘token’]) && !empty($_ssion[‘token’]) && $_ssion[‘token’] == $token &a小时代海报mp;& ($time – $_ssion[‘expire_time’] < $expire)) {

return fal;

} el {

$_ssion[‘token’] = $token;

$_ssion[‘expire_time’] = $time;

//ssion写入的时候会等待整个页面加载完成,用此函数可以立即写入

ssion_write_clo();

return true;

}

}

//删除存入的值

function cancelrepeatsubmit() {

unt($_ssion[‘token’]);

unt($_ssion[‘expire_time’]);

}

3、token销毁法

思路:当页面进行加装的时候生成token,存在ssion中,并写在表单里。表单提交的时候随表单提交给服务端,服务端通过ssion存入的token与token进行比较,若相等,则销毁esion中存入的token,当页面遭到二次提交的时候,由于存入ssion中的token不存在而报错。下面是代码

/**

* 第二种方案

* 1、产生token,并存在ssion中

* 2、随页面生成

* 3、提交页面与ssion进行比对,成功后对ssion进行销毁

* 4、第二次提交则不存在这个值而报错

* @param type $uniqueid

* @return typerp解决方案e

*/

function createtoken($uniqueid) {

$uniqueid = empty($uniqueid) ? yii::app()->ur->id . yii::app()->ur->name . yii::app()->ur->mihome : $uniqueid;

$token = md5(“wms_check2_repeat” . $uniqueid);

$_ssion[‘form_token’] = $token;

​ssion_write_clo();

return $token;

}

function checktoken($token) {

if (!ist($_ssion[‘form_token’]) || empty($_ssion[‘form_token’]) || $_ssion[‘form_token’] != $token) {

return fal;

} el {

unt($_ssion[‘form_token’]);

return true;

}

}

上面总结了三种方法,个人感觉第一种跟第二种方法配合着用会达到更好的效果。第二种方法与第三种方法个人感觉第三种要有优势点。

第二种与第三种方法都是把token写在ssion中,这种方法好处是节省存储空间,但坏处是由于ssion是需要整个页面加载完毕才能写入,故当整个页面加载比较慢,且用户点击多次提交,可能由于ssion还没写入导致还认为是第一次输入。导致验证不起作用。好在php函数提供了一个牛逼的函数。 ssion_write_clo(),可以立即把ssion写入,不用等待页面加载完成。同事对于ssstrideion的存入也有很多种方法可以选择,可以存在redis,memcache或者都可以的。

本文发布于:2023-04-07 05:40:22,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/5115078aab7e7c26928c3a556962ed35.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:页面防重复提交方法总结.doc

本文 PDF 下载地址:页面防重复提交方法总结.pdf

上一篇:浅尝https
下一篇:返回列表
标签:页面   种方法   按钮   表单
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图