
PHPの入力フォームでサブミットボタンを押すと、データベースのあるカラムに1が入力されるようにしたのですけど、ここで変な自体が起きてしまいまして、。。
POSTで受け渡先のページが自分自身の場合になっておりますが、 submitボタンを押していないにもかかわらず、画面の更新をするだけで、データーベースに同じ情報が更新した回数分だけ、登録されてしまうのですが、なんでなんでしょうか 教えてください。よろしくお願いします。
<?php
if (@$_POST['friend_req']) {
try{
require_once("../../db/connect_db.php");
$sql = "INSERT INTO friend(user_i, req_fg, user_you, add_fg) VALUES(?,?,?,?)";
$datas=array($user_id, 1, $_GET['no'], 0 );
$stmt = $pdo->prepare( $sql);
$stmt->execute($datas);
}catch(PDOException $e){
die($e->getMessage());
}
}
?>
<form method="post" action="<?=HOME?>universe/users/profile.php?no=<?php echo $_GET['no'];?>">
<input type="submit" name="friend_req" value="友人申請" >
</form>
No.1ベストアンサー
- 回答日時:
postしたページのリロードは、再度postすることです。
<?php
if (@$_POST['friend_req']) {
try{
require_once("../../db/connect_db.php");
$sql = "INSERT INTO friend(user_i, req_fg, user_you, add_fg) VALUES(?,?,?,?)";
$datas=array($user_id, 1, $_GET['no'], 0 );
$stmt = $pdo->prepare( $sql);
$stmt->execute($datas);
header("Location:".$_SERVER["SCRIPT_NAME"]);
}catch(PDOException $e){
die($e->getMessage());
}
}
?>
的な、INSERTしたら別ページに飛ぶようにしないとダメです
普通は更新したら「更新完了ページ」に飛ばすもんですけどね
ちなみにheaderで飛ばすので、HTMLの出力をする前に組み込む必要があります
あとPOSTとGETを組み合わせて使うのはかなり気を使わないといけません
$_SERVER["SCRIPT_NAME"]では飛べないし、仕様をよく検討してみてください
ありがとうございます。postしたページのリロードは、再度postすることということを知りませんでした。 headerに関しては、ただ単に飛ばすだけだとおもっていたのですが、$_POSTをリロードさせない役割もあったのですね。過去にPHPで実験として作成したものでも、気付いていないだけで、よくにた状況のものがいくつかでてきました。コメントがリアルタイムで表示されるものや、いいねボタンをおすといいねがつくようなものも自分のページにheaderなしで、飛ばしていたので、今確認したところ、更新するたびにいいねがついてしまってました。自分ではまったく気付かなかったので、とても感謝です。同時に少し疑問もでてきました。頭を整理してみます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
データ送信をボタンを押さずに...
-
PHP table内、<a href使って su...
-
FORMで送信ボタンと戻るボタン...
-
PHPのif文でその処理を途中で抜...
-
ファイルの更新日時でのソート
-
インクルードした部分が表示さ...
-
onedrive にexcelファイルをア...
-
.htaccessにphp_valueが使用できな
-
「クラス関数」「メンバ関数」...
-
file_get_contentsでcss読み込み
-
#!/usr/local/bin/phpはどこに...
-
PEARコマンドが使えない・・・
-
PHPExcel処理速度が遅い
-
.phpのファイルを開けない!
-
prototype.jsのAjax.Request
-
php,mysqlにて画像パス保存/表...
-
SELECTの値を保持する
-
xamppを使う場合のphpファイル...
-
phpでのメール転送(添付ファイ...
-
asp.netのクラスについて
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
FORMで送信ボタンと戻るボタン...
-
テキストボックスにデータベー...
-
引数を正しく読み込む方法
-
【PHP】ページを更新すると勝手...
-
form actionで二つ送信先を指定...
-
wordpressのテーマSightの日付表示
-
GETメソッドで文字列として+を...
-
変数について
-
header.locationで、画面遷移、GET
-
inputタグでphpを呼び出す際、...
-
javascriptでポスト送信したデ...
-
セッションにオブジェクトを登...
-
セッション PHPとHTML
-
Wordpressのコメント欄受付・表...
-
ボタンのクリック数を合計保存...
-
ユーザーに入力してもらった値...
-
問題部分がJavascriptかPHPか分...
-
PHP table内、<a href使って su...
-
データベース接続 ログインフ...
-
PHPとCSVで簡易データベースな...
おすすめ情報
補足ですが、データベースに 1 が登録されていない段階では、更新してもなにも登録されないのですが、 一度、データベースに登録したあとに、 更新すると、submitボタンを押していないけどもsubmitボタンを押したときのように、更新した回数だけレコードが増えています。