微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PHP防止post重复提交数据的简单例子

在某帝国面试的时候问题了这个题: 怎么处理post提交重复的问题,后来跟@暖阳交流,他说记录时间,我没有明白,我想的是用session在表单页面记录下,然后提交页面判断,如果相等则视为成功,并清空session,但有个问题是如果表单页面是html的呢,乍办?要不调个PHP验证的页面?类似验证码的功能. 还有的说用 header头设置过期时间...但没试.以下是我PHP写的,经测试可用.

代码如下:
PHP
//开启session
session_start();

//如果有提交标识
if(isset($_GET['action']) && $_GET['action'] === 'save'){

//如果有session且跟传过来的值一样才算提交
if(isset($_SESSION['__open_auth']) && isset($_POST['auth']) && $_SESSION['__open_auth'] == $_POST['auth']){
print_r($_POST);
$_SESSION['__open_auth'] = null;//清空
} else {

//走起
header("location: post.PHP");
}
exit();
}

//授权
$auth = $_SESSION['__open_auth'] = time();

?>



<Meta charset="UTF-8">
post


PHP?action=save" method="post">














原文地址:https://www.jb51.cc/php/24568.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐