ホームページ > バックエンド開発 > PHPチュートリアル > ページを更新すると最後のメッセージが再び表示されるのはなぜですか?

ページを更新すると最後のメッセージが再び表示されるのはなぜですか?

WBOY
リリース: 2016-06-23 14:11:22
オリジナル
774 人が閲覧しました


<?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 の観点から見ると、要求されたページ データがセッションに配置されると、問題

あなたが省略した部分はまさにこれです 問題の最も可能性の高い原因はこれです

送信後にヘッダーがジャンプします。

問題を特定できるように、投稿者が投稿ページを投稿してもらえますか?

繰り返しの送信を防ぐためにフォーム トークンの検証を追加します

全部投稿した方が良いでしょう。 。


<?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>"; }
ログイン後にコピー


エコーを複数回押します

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート