> php教程 > php手册 > 본문

[PHP]防止表单重复提交的几种方法

WBOY
풀어 주다: 2016-06-06 19:49:40
원래의
1040명이 탐색했습니다.

--------------------------------------------------------------------------------------------------- 1. 使用JS让按钮在点击一次后禁用(disable)。= 防止多次点击发生,实现方式较简单。 缺点:若客户端禁止JavaScript脚本,则失效。 2. 在提交成功后

---------------------------------------------------------------------------------------------------

1. 使用JS让按钮在点击一次后禁用(disable)。=> 防止多次点击发生,实现方式较简单。

  缺点:若客户端禁止JavaScript脚本,则失效。

 

2. 在提交成功后执行页面重定向(redirect)。=> 转到提交成功信息页面。

  特点:避免F5重复提交,消除浏览器前进和后退按导致的同样问题。

 

3. 表单隐藏域中存放session(表单被请求时生成的标记)。=> 接收表单数据后,检查此标志值是否存在,先进行删除,然后处理数据; 若不存在,说明已提交过,忽略本次提交。

<span>/*</span><span>
|---------------------------------
|原理 & 代码示例
|@黑眼诗人 <www.farwish.com>
|---------------------------------
</www.farwish.com></span><span>*/</span>
<span>//</span><span>服务端生成随机数存入session, 分配至表单页</span>
<span>$data</span>['sess_id'] = <span>$_SESSION</span>['sid'] = <span>mt_rand</span>(1000, 9999<span>);
</span><span>$this</span>->load->view('form', <span>$data</span><span>);

</span><span>//</span><span>表单页隐藏域存放此session值</span>
<input type="hidden" name="sid" value="<?=<span>$sess_id</span>; ?>">

<span>//</span><span>处理</span>
<span>if</span>(<span>$_POST</span>['sid'] != '' && $_POST['sid'] == $_SESSION['sid']<span>)
{
 </span><span>unset</span>(<span>$_SESSION</span>['sid'<span>]);

 </span><span>echo</span> '处理数据'<span>;
}
</span><span>else</span><span>
{
 </span><span>echo</span> '已提交过表单'<span>;
}</span>
로그인 후 복사

 

4. 数据库唯一索引约束(最有效的防止重复数据的方法)。

 

Link: http://www.cnblogs.com/farwish/p/3911588.html

@黑眼诗人 

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿