Heim >Backend-Entwicklung >PHP-Tutorial >php防止用户刷新 重复提交的方法

php防止用户刷新 重复提交的方法

WBOY
WBOYOriginal
2016-07-25 09:00:131065Durchsuche
在防止用户刷新方面,即时销毁$_POST['name']的方法是不行的,或许是有缓存的原因,这种方法失败。 本文使用session来解决,有需要的朋友,可以参考下。

Session保存在服务器端,在PHP过程中改变Session变量的值后,即保存在服务器端,下次访问这个变量时,得到是新赋的值,所以,可以用一个Session变量记录表单提交的次数,大于1时,就不在处理表单中的数据。

测试代码:
<?php
/**
 * 防止刷新 重复提交
* site bbs.it-home.org
*/
if (isset($_POST['action']) && $_POST['action'] == 'submitted') {  
      session_start();  
      isset($_SESSION['submit_time']) or die ("no session");  
      if ($_SESSION['submit_time']==0){  
              print '<pre class="brush:php;toolbar:false">';  
        
              print_r($_POST);  
              print 'Please try again';  
        
              print '
'; $_SESSION['submit_time']=1; echo $_SESSION['submit_time']; } else { print '
';  
        
              print_r($_POST);  
              echo "However you have submitted";  
              print '
'; } } else { session_start() or dir("session is not started"); $_SESSION['submit_time']= 0; // isset($_SESSION['submit_time']) or die ("session var is not created"); // echo $_SESSION['submit_time']; ?>
Name:
Email:
Beer:

上面代码有个缺点: 没有明确销毁Session,失效的Session文件可能仍然保留在服务器文件系统中。 哪位有好的办法,还请分享一下。



Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn