> 백엔드 개발 > PHP 튜토리얼 > 为什么刷新一下页面就又重复了上次的留言

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

WBOY
풀어 주다: 2016-06-23 14:11:22
원래의
775명이 탐색했습니다.


<?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>
로그인 후 복사


回复讨论(解决方案)

<?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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿