如何防止页面刷新的时候,表单重复被提交! 如何防止页面刷新的时候,表单重复被提交!希望有代码,有注释,有思路,谢谢哦! 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 摆了个度吧:php 表单重复提交http://www.baidu.com/s?bs=simplexml&f=8&rsv_bp=1&rsv_spt=3&wd=php+%B1%ED%B5%A5%D6%D8%B8%B4%CC%E1%BD%BB&rsv_n=2&inputT=4074 http://www.baidu.com/s?wd=php+%B1%ED%B5%A5%D6%D8%B8%B4%CC%E1%BD%BB&rsv_bp=0&rsv_spt=3&rsv_n=2&inputT=664 使用session控制。表单提交一般都是用到php后台了,那么你就在php里面处理完html提交数据后销毁数据。 传了个文档,好多字……http://download.csdn.net/detail/dmtnewtons/4176949 不需要那么复杂,提交完了一个header("location:");重定向下 1.提交後彈出一個js 提示,他不確定這個提示是無法再提交的.2.生成隨機token 提交需要驗證 不通過的token 一律拋棄 使用Cookie处理 使用Cookie记录表单提交的状态,根据其状态可以检查是否已经提交表单,请见下面的代码:1.< ?php 2.if(isset($_POST['go'])){setcookie("tempcookie","",time()+30); 3.header("Location:".$_SERVER[PHP_SELF]);exit(); 4.} if(isset($_COOKIE["tempcookie"])){ 5.setcookie("tempcookie","",0);echo "您已经提交过表单"; 6.}?> 如果客户端禁止了Cookie,该方法将不起任何作用,这点请注意。3.使用Session处理 利用PHP的Session功能,也能避免PHP表单重复提交。Session保存在服务器端,在PHP运行过程中可以改变Session变量,下次访问这个变量时,得到的是新赋的值,所以,可以用一个Session变量记录表单提交的值,如果不匹配,则认为是用户在重复提交,请见如下代码:1.< ?php 2.session_start();//根据当前SESSION生成随机数 3.$code = mt_rand(0,1000000); 4.$_SESSION['code'] = $code; 5.?> 在页面表单上将随机数作为隐藏值进行传递,代码如下:1.< input type="hidden" name="originator" value="< ?=$code?>"> 在接收页面的PHP代码如下:1.< ?php 2.session_start(); 3.if(isset($_POST['originator'])) { 4.if($_POST['originator'] == $_SESSION['code']){ 5.// 处理该表单的语句,省略 6.}else{ 7.echo ‘请不要刷新本页面或 重复提交表单!’; 8.} 9.}?> 还有两种方法没有贴出来,请进:http://www.phpnewer.com/index.php/Cjwt/detail/id/356 如何在CENTOS6.3中安装apache+php+mysql(基础问题) 看一下传参数这个问题,我不太明白 关于在PHP文件中无法引进Jquery.js和AutoComplete问题 怎样在apache服务器启动时候设置全局变量数组到内存?? 请教一下如何获得日本的日期 时间 与星期 我遇到的奇怪问题 几个php处理mysql问题 php论坛怎么显示在线列表? PHP4如何连接accesss,sql-server bbcode解析 [code] 的问题 获取POST参数 php数组问题 如何判断两个数组不同的数据,并且输出
php 表单重复提交
http://www.baidu.com/s?bs=simplexml&f=8&rsv_bp=1&rsv_spt=3&wd=php+%B1%ED%B5%A5%D6%D8%B8%B4%CC%E1%BD%BB&rsv_n=2&inputT=4074
表单提交一般都是用到php后台了,那么你就在php里面处理完html提交数据后销毁数据。
http://download.csdn.net/detail/dmtnewtons/4176949
一个header("location:");重定向下
2.生成隨機token 提交需要驗證 不通過的token 一律拋棄
2.if(isset($_POST['go'])){setcookie("tempcookie","",time()+30);
3.header("Location:".$_SERVER[PHP_SELF]);exit();
4.} if(isset($_COOKIE["tempcookie"])){
5.setcookie("tempcookie","",0);echo "您已经提交过表单";
6.}?>
如果客户端禁止了Cookie,该方法将不起任何作用,这点请注意。3.使用Session处理 利用PHP的Session功能,也能避免PHP表单重复提交。Session保存在服务器端,在PHP运行过程中可以改变Session变量,下次访问这个变量时,得到的是新赋的值,所以,可以用一个Session变量记录表单提交的值,如果不匹配,则认为是用户在重复提交,请见如下代码:1.< ?php
2.session_start();//根据当前SESSION生成随机数
3.$code = mt_rand(0,1000000);
4.$_SESSION['code'] = $code;
5.?>
在页面表单上将随机数作为隐藏值进行传递,代码如下:1.< input type="hidden" name="originator" value="< ?=$code?>">
在接收页面的PHP代码如下:1.< ?php
2.session_start();
3.if(isset($_POST['originator'])) {
4.if($_POST['originator'] == $_SESSION['code']){
5.// 处理该表单的语句,省略
6.}else{
7.echo ‘请不要刷新本页面或 重复提交表单!’;
8.}
9.}?> 还有两种方法没有贴出来,请进:http://www.phpnewer.com/index.php/Cjwt/detail/id/356