码迷,mamicode.com
首页 > Web开发 > 详细

php防止表单重复提交

时间:2019-04-17 09:36:09      阅读:189      评论:0      收藏:0      [点我收藏+]

标签:发送   比较   BMI   ofo   isset   status   article   array   超过   

后端防止重复提交的基本原理:
服务器返回表单页面时,会先生成一个subToken保存于session,并把该subToen传给表单页面。当表单提交时会带上subToken,服务器获取表单信息判断session保存的subToken和表单提交subToken是否一致。若不一致或session的subToken为空或表单未携带subToken则不通过。
首次提交表单时session的subToken与表单携带的subToken一致走正常流程,然后拦截器内会删除session保存的subToken。当再次提交表单时由于session的subToken为空则不通过。从而实现了防止表单重复提交。

$session = Yii::app()->session;
$user_id = $this->user->id;
$sessionKey = $user_id.‘_is_sending‘;
if(isset($session[$sessionKey])){
$first_submit_time = $session[$sessionKey];
$current_time = time();
if($current_time - $first_submit_time < 10){
$session[$sessionKey] = $current_time;
$this->response(array(‘status‘=>1, ‘msg‘=>‘不能在10秒钟内连续发送两次。‘));
}else{
unset($session[$sessionKey]);//超过限制时间,释放session";
}
}
//第一次点击确认按钮时执行
if(!isset($session[$sessionKey])){
$session[$sessionKey] = time();
}

可以参考以下链接,写的比较详细:https://blog.csdn.net/Huozhiwu_11/article/details/78742886
https://www.jb51.net/article/91623.htm

php防止表单重复提交

标签:发送   比较   BMI   ofo   isset   status   article   array   超过   

原文地址:https://blog.51cto.com/13238147/2379821

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!