|
在防止用户刷新方面,即时销毁$_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 '登录后复制 ';
print_r($_POST);
echo "However you have submitted";
print '登录后复制 上面代码有个缺点: 没有明确销毁Session,失效的Session文件可能仍然保留在服务器文件系统中。 哪位有好的办法,还请分享一下。 |
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号