表单防止多次提交php,php防止表单重复提交

后端防止重复提交的基本原理:

服务器返回表单页面时,会先生成一个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();

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值