如何避免页面刷新数据重复写入数据库

如何避免页面刷新数据重复写入数据库

如何避免页面刷新数据重复写入数据库

当表单的数据是提交给本页面处理并写入数据库时,点提交后,刷新页面的话使数据重复写入数据库。网上搜索一下,发现了不少的解决方案:

一、把一页面分开为两个,数据提交给另一个页面处理,之后再跳到输入页面。

优点:避免了刷新的影响,并可连续提交数据。

缺点:当用户在还没有完整的填写表单时,点了提交。若不执行数据入库操作又要保留用户之前输入的内容,用php来实现有些困难或说不方便。(当然,用js实现可能比较容易。在此约定本文只是从php的角度评价,研究php的运用)

*总的说来,这是一种不错的解决方案。

二、在session中保存变量

_SESSION['submit']=false

提交后改为true

检测变量

if(_SESSION['submit']=true){

echo"text";

exit();

}

优点:避免了刷新的影响,并且只有一个页面,没有第一种方法的缺点

缺点:只能提交一次,不能连续提交数据。

*有可取之处,但适用面太窄。

三、在数据入库之前执行一次验证查询,看数据库里是否已经存在了相同的记录,由此来决定是否写入数据。

优点:没有了前两种方法的缺点。

缺点:代码不精简,操作繁琐。再说有时并不排斥保存完全相同的信息。

*实现代价太高,副作用过大。

有没有没整合三种方法优点不要其缺点的方法呢?有!下面就是一种不错的解决方案,与大家分享:

<?php

session_start();

if(!isset(_SESSION['h'])){

_SESSION['h']=1;

}

_SESSION['h']++;

if(isset(_POST['h'])and_SESSION['h']==_POST['h']){

echo'<fontcolor=green>您点提交按钮了</font>';

}else{

echo'<fontcolor=red>您没有点提交</font>';

}

?>

<formaction="im.php"method=post>

b:<inputtype="text"name=b><P>

<inputtype="hidden"name=hvalue=<?phpecho_SESSION['h']+1;?>>

c:<inputtype="text"name=c><P>

d:<inputtype="text"name=d><P>

<inputtype="submit"value=提交>