为什么刷新一下页面就又重复了上次的留言

php中文网
发布: 2016-06-23 14:11:22
原创
926人浏览过


<?phpinclude('conn.php');if($_POST['username']){$sql = "insert into easy values('$_POST[username]','$_POST[title]','$_POST[content]',now())";mysql_query($sql);}?><div align = "center"><table width=500 border="0" cellpadding="5" cellspacing="1" bgcolor="#add3ef">//中间是表单样式,略去<?php   $SQL="SELECT * FROM easy order by posttime desc ";  $query=mysql_query($SQL);  while($row=mysql_fetch_array($query)){?>  <tr bgcolor="#eff3ff">  <td>标题:<?=$row[title]?></td>   <td>用户:<?=$row[username]?></td>  <td>  <?= $row[posttime]?></td>  </tr>  <tr bgColor="#ffffff">  <td>内容:<?= ($row[content])?></td>  </tr><?php  }?></table>
登录后复制

降重鸟
降重鸟

要想效果好,就用降重鸟。AI改写智能降低AIGC率和重复率。

降重鸟 113
查看详情 降重鸟

回复讨论(解决方案)

<?phpinclude('conn.php'); if($_POST['username']) //我想是不是这里有问题,但只是刷新页面,并没有传递数据呀
登录后复制

php 不太懂 不过从jsp 的角度出发如果 请求页面数据放在session里面就有那个问题

你略去的部分,恰恰就是最可能的问题原因

提交后header跳转一下。

楼主可否贴出你的提交页面,这样才能定位问题呢。

加一个表单令牌的验证防止生重复提交

我还是全都贴上吧。。


<?phpinclude('conn.php');if($_POST['username']){$sql = "insert into easy values('$_POST[username]','$_POST[title]','$_POST[content]',now())";mysql_query($sql);}?><html><script language = "javascript">function checkMessage(){  if(msgform.username.value == "")  {     alert("用户名不能为空!");     msgform.username.focus();     return fause;  }  if(msgform.title.value =="")  {     alert("标题不能为空!");     msgform.title.focus();     return fause;   }  if(msgform.content.value =="")  {     alert("留言内容不能为空!");     msgform.content.focus();     return fause;   }return true;}</script><body bgcolor = "#FFFFFF" text = "#000000"><h1 align = center><font color = blue>给我留言</font></h1><form name = "msgform" method = "post" action = "input.php" enctype = "multipart/form-data" onsubmit = "return checkMessage()"><table width = "64%" border = "0" cellspacing = "1" cellpadding = "3" bgcolor = "#66CCFF" align = "center"><tr><td width = "48%">用 户:  <input type = "txet" name = "username"></td></tr><tr><td colspan = "2">标 题:<input type = "text" name = "title" size = "60" maxlength = "50"></td></tr><tr><td colspan = "2"><textarea name = "content" rows = "10" cols = "100"></textarea></td></tr><tr><td><div align = "right"><input type = "submit" name = "sub" value = "提交"></div></td><td><input type = "reset" name = "Rewrite" value = "重写"></td></tr></table><div align = "center"><table width=500 border="0" cellpadding="5" cellspacing="1" bgcolor="#add3ef"><?php   $SQL="SELECT * FROM easy order by posttime desc ";  $query=mysql_query($SQL);  while($row=mysql_fetch_array($query)){?>  <tr bgcolor="#eff3ff">  <td>标题:<?=$row[title]?></td>   <td>用户:<?=$row[username]?></td>  <td>  <?= $row[posttime]?></td>  </tr>  <tr bgColor="#ffffff">  <td>内容:<?= ($row[content])?></td>  </tr><?php  }?></table></div></form></body></html>
登录后复制

这个你必须明白一个原理:如果浏览器没有进行跳转,那么你之前的提交动作会被保留,如果这时候你刷新,就会再次出发这个提交动作,虽然不是你点击提交的,但实际上也相当于你提交了

多以提交完以后,你要进行跳转或者其他方式取消掉提交的动作,不要让浏览器保留该动作

<?phpinclude('conn.php'); if($_POST['username']){ $sql = "insert into easy values('$_POST[username]','$_POST[title]','$_POST[content]',now())";mysql_query($sql);  //意思就是在这之后做一个跳转处理或者其他去掉提交动作处理,比如echo '<meta http-equiv="refresh" content="1;url=index.php">'}?>
登录后复制

这个你必须明白一个原理:如果浏览器没有进行跳转,那么你之前的提交动作会被保留,如果这时候你刷新,就会再次出发这个提交动作,虽然不是你点击提交的,但实际上也相当于你提交了

多以提交完以后,你要进行跳转或者其他方式取消掉提交的动作,不要让浏览器保留该动作
+1
提交成功后,跳转一下页面就可以了

if($_POST['username']){ $sql = "insert into easy values('$_POST[username]','$_POST[title]','$_POST[content]',now())";mysql_query($sql);echo echo "<script language=\"javascript\">alert('提交成功');location.href='add.php';</script>"; }
登录后复制

多个打了个echo

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号