只需要在表单里生成一个token(随机字符串),然后用个input装起来,设置hidden。第一次post处理完数据后把token存入session,接下来每次post判断一下token跟session中的一不一样,一样则说明数据处理过了。
1 <?php
2 session_start();
3
4 //读取服务器端的session_id,如果没有的话赋值为-1
5 $session_id = empty($_SESSION['session_id']) ? -1 : $_SESSION['session_id'];
6
7 //读取客户端的post_id,如果没有的话赋值为-2
8 $post_id = empty($_POST['post_id']) ? -2 : $_POST['post_id'];
9
10 //判断两个id是否相同,相同则说明已经处理过一次,不同则进行处理
11 if($session_id == $post_id){
12
13 echo "<h1>已经处理过了,不管了</h1>";
14
15 }else{
16
17 //如果页面还没有提交过表单,则显示表单,否则处理post过来的数据
18 if($post_id == -2){
19 ?>
20 <html>
21 <body>
22 <form action="index.php" method="post">
23 <input type="text" hidden="hidden" name="post_id" id="" value="<?php echo rand(1, 999999); ?>" />
24 <input type="text" name="test" id="test" value="" />
25 <input type="submit" value=""/>
26 </form>
27 </body>
28 </html>
29 <?php
30 }else{
31
32 echo "<h1>正在处理</h1>";
33
34 //处理过后吧post_id存入session,方便下次比较
35 $_SESSION['session_id'] = $post_id;
36
37 }
38
39 }
40 ?>