いつもお世話になります。
PHP Ver.4.46 MySQL Ver.4.0.27 です。
フォームよりMySQLのデータベースへ書き込んでその内容を表示しようと思っています。
しかし、更新ボタンを押すと
、『情報を再送信する必要があります』と表示され、『はい』を押すと、
テキストボックスの内容が空白なのに同じデータが次々と書き込まれてしまいます。
過去ログを調べてよく似たようなものがあったので
http://oshiete1.goo.ne.jp/qa3473685.html
試してみましたが、ダメでした。
//★★★★★★★★の行を追加してみました。
よろしくお願いいたします。
スクリプトは以下のようなものです。
<form method="POST" action="<?php echo $_SERVER["PHP_SELF"]?>">
<table border="1">
<tr>
<td>お名前</td>
<td><input type="text" name="g_name" size="30"></td>
</tr>
<tr>
<td>メールアドレス</td>
<td><input type="text" name="g_mail" size="30"></td>
</tr>
<tr>
<td>メッセージ</td>
<td>
<textarea rows="5" cols="30" name="g_mes"></textarea>
</td>
</tr>
<tr>
<td colspan="2">
<input type="submit" value="書き込む" onClick="return confirm('書き込んで良いですか?')">
</td>
</tr>
</table>
</form>
<?php
$sv = "localhost";
$dbname = "guestbook";
$user = "root";
$pass = "********";
// データベースに接続する
$conn = mysql_connect($sv, $user, $pass) or die("接続エラー");
mysql_select_db($dbname) or die("接続エラー");
?>
<?php
// POSTメソッドで送信された場合は書き込み処理を実行する
if ($_SERVER["REQUEST_METHOD"] == "POST") {
// フォームからデータを受け取る
$g_name = cnv_dbstr($_POST["g_name"]);
$g_mail = cnv_dbstr($_POST["g_mail"]);
$g_mes = cnv_dbstr($_POST["g_mes"]);
// 名前とメッセージが入力されていればデータの追加を実行する
if (!empty($g_name) and !empty($g_mes)) {
// データを追加する
$sql = "INSERT INTO guestdata(g_name, g_mail, g_mes, g_date) ";
$sql .= "VALUES(";
$sql .= "'" . $g_name . "',";
$sql .= "'" . $g_mail . "',";
$sql .= "'" . $g_mes . "',";
$sql .= "'" . date("Y/m/d H:i:s") . "'";
$sql .= ")";
$res = mysql_query($sql, $conn) or die("データ追加エラー");
if ($res) {
echo "<p>書き込みありがとうございました</p>";
//★★★★★★★★header("Location:" . $_SERVER["PHP_SELF"] . ".php");
//$_SERVER["REQUEST_METHOD"]="";//rqg 初期化 これではダメだった
}else{
echo "<p>書き込み失敗</p>";
}
}
// 名前やメッセージが空白の場合はエラーメッセージを出力する
else {
echo "<p><b>お名前とメッセージを入力してください</b></p>";
}
}
// SQLコマンド用の文字列に変換する関数
function cnv_dbstr($string) {
// タグを無効にする
$string = htmlspecialchars($string);
// magic_quotes_gpcがONの場合はエスケープを解除する
if (get_magic_quotes_gpc()) {
$string = stripslashes($string);
}
// SQLコマンド用の文字列にエスケープする
$string = mysql_real_escape_string($string);
return $string;
}
?>
No.4ベストアンサー
- 回答日時:
手前味噌ですが^^;、挙げていただいた
http://oshiete1.goo.ne.jp/qa3473685.html
これの3が一番手軽ですよ。
[送信側]
<input type="hidden" name="form_time" value="<?= time() ?>" /><!-- ←これ追加 -->
<input type="submit" value="書き込む" onClick="return confirm('書き込んで良いですか?')">
[受信側]
define("TIME_LIMIT", 60 * 5); // 秒単位、この場合だと5分
// 時間切れ
if( time() > $_POST["form_time"] + TIME_LIMIT ) {
// エラーとか
}
// 正常なときクエリ発行
else
{
$res = mysql_query($sql, $conn) or die("データ追加エラー");
}
厳密にやりたいなら先URLの4みたいな感じにしないといけませんけどね。
wp_さん、ご丁寧にレスありがとうございます。
いろいろと試してみました。
取りあえず、更新ボタンで即再書き込みがされてしまうようなことはなくなりました。
いろいろと教えていただきありがとうございました。
No.3
- 回答日時:
>//★★★★★★★★ header("Location:" . $_SERVER["PHP_SELF"] . ".php");
自身にリダイレクトしたら駄目です。^^;
別ページに遷移させる手法の場合はPOSTされても影響がないページでないといけません。
一番最良なのはPOSTの影響を受けない静的ページ(hogehoge.htmlなど)に飛ばしてあげることです。
// Locationで飛ばした場合にF5を防げたかどうか分かりませんが・・・
// 当方現在テスト用サーバを潰してしまって確認できひん
wp_さん、レスありがとうございます。
>自身にリダイレクトしたら駄目です。^^;
この意味がわかりました。
どうもありがとうございます。
No.2の方の解答からもLocationは、厳しそうです。
他の方法を考えます。
No.2
- 回答日時:
header関数は、何かを出力する前に実行しないと動きません。
headerの前にechoで文字出力をしているので実行が無効になってしまいます。
重複投稿を拒否するのでしたら、直近のLOGと同一の書き込みなのかを調べて、同一ならばエラーを返すとかしたほうがいいかもしれません。
moon_nightさん、レスありがとうございます。
>headerの前にechoで文字出力をしているので実行が無効になってしまいます。
headerを使用するのは、この場合かなり厳しいことがわかりました。
どうもありがとうございました。
>直近のLOGと同一の書き込みなのかを調べて、同一ならばエラーを返すとかしたほうがいいかもしれません。
MySQLを使い始めたばかりで、方法がまだわかりません。
これから、研究します。
No.1
- 回答日時:
データをDBに書き込む記述をHTMLの上にもっていってみてはどうでしょうか?
DBに書き込む記述
↓
受け取ったデータの内容を初期化(unsetとかで)
↓
HTMLの記述
にしてみてはどうでしょうか?
tamaneleさん、今晩は。レスありがとうございます。
早速やってみました。
Warning: mysql_real_escape_string() [function.mysql-real-escape-string]: Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2) in /***/***/www/****/***/guestbook1.php on line 66
と、いうエラーが出力され、書き込みもできなくなりました。
line 66は、
65// SQLコマンド用の文字列にエスケープする
66$string = mysql_real_escape_string($string);
67return $string;
です。
このline 66
も、
<form method="POST" action="<?php echo $_SERVER["PHP_SELF"]?>">
の上に持って行ってみました。
また、下にしても同じでした。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- AJAX JavascriptからPHPへのAjax通信でnullが返ってくる 3 2022/08/03 22:00
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- PHP PHP MySql 画像を取得 1 2022/06/04 14:05
- PHP PHPで画像の渡しが上手く行きません。 1 2023/02/02 09:39
- PHP if(preg_match("/[^0-9]/",$gu_d)){意味を教えてください。 1 2022/05/06 05:37
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- Excel(エクセル) PHPプログラムをエクセルに張り付けると検索ボックスがでてくる! 3 2022/05/08 07:10
- PHP htmlで複数の個数入力欄を表示させるには 1 2022/09/20 03:11
- PHP 入力した部分を表示させたまま(保持)するにはどうすれば良いでしょうか? 1 2023/01/25 11:14
- PHP PHP MySQLに画像を直接保存 2 2022/06/05 11:50
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
<VB.NET>INSERT文でDBにデータ...
-
データベースに存在するデータ...
-
ResultSetインターフェイスでの...
-
VBA ACCESS SQL...
-
insert1つの処理でもトランザ...
-
JAVA SQLServerException 列名 ...
-
phpでMySQLのデータベースにア...
-
INSERT,DELETEを同時に
-
SQL文が実行できません
-
ランダム文字列をDBにINSERT
-
DBで検索結果に該当するデータ...
-
日付範囲で検索した後に降順に...
-
実行時エラー3131 FROM 句の構...
-
OracleからAccessへのインポート
-
MySQLでデータベースにデータin...
-
mysql>PHPにデータ表示、10件ご...
-
phpでmysqlを使ってデータベー...
-
VBAについて質問です
-
ヒアドキュメントについて
-
codeigniter 複数モデルでトラ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
JAVA SQLServerException 列名 ...
-
<VB.NET>INSERT文でDBにデータ...
-
ResultSetインターフェイスでの...
-
Pro*Cの構文エラー
-
insert1つの処理でもトランザ...
-
データベースに存在するデータ...
-
VBA ACCESS SQL...
-
INSERT,DELETEを同時に
-
MySQLのINSERT時にたまに重複に...
-
VB.NET エラーになる箇...
-
PHP&MySQLでの文字列+数列の一...
-
PHP初心者です。syntax error, ...
-
like検索の複数キーワードで、...
-
php MySQL で、更新ボタンを押...
-
php postgres Insert と updat...
-
ASPでSQL文を使う場合に。
-
Q&Aサイトを作成していてURLの...
-
チェックボックスからの複数検...
-
php データベースから値を取得する
-
phpでforeach ($stmt as $row)...
おすすめ情報