PHPとMySQLでゲームの掲示板を作りたい。
ここに質問の内容を詳しく書いてください。
(例)簡単なToDoリストとブログを作成した後ついに自分一人でPHPとMySQLを使い、ずっと作りたかったゲームの掲示板の作成に取り組んでいるのですがPOSTで送られてきた内容をDBに入れるところでつまづいてしまいました。
board1.phpからPOST形式でboard2.phpに送り、PDOでDBの書き込みをし、board1.phpからデータを引っ張って表示させようとしています。
特にエラーメッセージが出てくるわけではないのですが、何度送信してphp Myadminを見ても追加されません。
どこが間違っているのか、教えていただけると幸いです。
該当のソースコード
//board1.php <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>掲示板</title> </head> <body> <h2>掲示板</h2> <form action="board2.php" method="POST"> <div> <label for="model">機種 : </label> <input type="radio" name="model" value="1" checked="checked">PS4 <input type="radio" name="model" value="2">PC <input type="radio" name="model" value="3">Switch </div> <div> <label for="purpose">目的 : </label> <select name="purpose"> <option value="1">カジュアルマッチ</option> <option value="2">ランクマッチ</option> <option value="3">訓練場</option> </select> </div> <div> <label for="user_id">ID : </label> <input id="user_id" type="text" name="user_id"> </div> <div> <label for="characters">募集キャラ : </label> <select name="characters"> <option value="1">特になし</option> <option value="2">ブラッドハウンド</option> <option value="3">ジブラルタル</option> <option value="4">ライフライン</option> <option value="5">パスファインダー</option> <option value="6">レイス</option> <option value="7">バンガロール</option> <option value="8">コースティック</option> <option value="9">ミラージュ</option> <option value="10">オクタン</option> <option value="11">ワットソン</option> <option value="12">クリプト</option> <option value="13">レヴナント</option> <option value="14">ローバ</option> <option value="15">ランパート</option> <option value="16">ホライゾン</option> <option value="17">ヒューズ</option> <option value="18">ヴァルキリー</option> </select> </div> <div> <label for="rank">ランク帯 : </label> <select name="rank"> <option value="1">特になし</option> <option value="2">ブロンズ帯</option> <option value="3">シルバー帯</option> <option value="4">ゴールド帯</option> <option value="5">プラチナ帯</option> <option value="6">ダイヤ帯</option> <option value="7">マスター帯</option> <option value="8">プレデター帯</option> </select> </div> <div> <label for="level">レベル : </label> <select name="level"> <option value="1">特になし</option> <option value="2">100以上</option> <option value="3">200以上</option> <option value="4">300以上</option> <option value="5">400以上</option> <option value="6">500</option> </select> </div> <div> <label for="number_player">募集人数 : </label> <select name="number_player"> <option value="1">1人</option> <option value="2">2人</option> </select> </div> <div> <label for="message">ひと言メッセージ : </label> <textarea id="message" name="message"></textarea> </div> <input type="submit" name="btn_submit" value="送信"> </form> //board2.php <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>掲示板</title> </head> <body> <h2>投稿完了</h2> <button onclick="location.href='board1.php'">戻る</button> <?php $boards = $_POST; $dsn = 'mysql:host=localhost;dbname=keijiban;charset=utf8'; $user = '入力済み'; $pass = '入力済み'; try { $dbh = new PDO($dsn,$user,$pass,[ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, ]); } catch(PDOException $e) { echo '接続失敗'. $e->getMessage(); exit(); }; return $dbh; $sql = 'INSERT INTO board(model, purpose, user_id, characters, rank, level, number_player, message) VALUES (:model, :purpose, :user_id, :characters, :rank, :level, :number_player, :message)'; $dbh->beginTransaction(); try { $stmt = $dbh->prepare($sql); $stmt->bindValue(':model', $boards['model'], PDO::PARAM_INT); $stmt->bindValue(':purpose', $boards['purpose'], PDO::PARAM_INT); $stmt->bindValue(':user_id', $boards['user_id'], PDO::PARAM_STR); $stmt->bindValue(':characters', $boards['characters'], PDO::PARAM_INT); $stmt->bindValue(':rank', $boards['rank'], PDO::PARAM_INT); $stmt->bindValue(':level', $boards['level'], PDO::PARAM_INT); $stmt->bindValue(':number_player', $boards['number_player'], PDO::PARAM_INT); $stmt->bindValue(':message', $boards['message'], PDO::PARAM_STR); $stmt->execute(); $dbh->commit(); echo '投稿しました'; } catch(PDOException $e){ $dbh->rollBack(); exit($e); } ?>
試したこと
board1.phpからPOSTで送られてきたデータをvar_dumpで調べたら内容は出てきたので送れているのですが、そこからがわかりません。参考にした人のを見るとこれでうまくいっているのですがこちらではうまくいきません。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
回答1件
あなたの回答
tips
プレビュー