こんにちは。
PHPとmySQLで検索システムとデータベースへの追加システムを作っています。
コードが検索システムが書かれているコードとINSERT文があるコードで2つに分かれており、INSERT文があるphp(add.php)を検索システムがあるphp(main.php)の下部(追加ボタンの下)に反映させたいです。
main.phpの109行目の<form action="add.php" method="post">を<form action="" method="post">に変更し、132行目以降にadd.php内の記述を行い、59行目(if ($_POST) { try {~ の部分)から記述されているphp内のadd.phpと重複する変数を削除し纏めてもの59行目の部分でエラーが出てしまいます。
main.php↓
<!DOCTYPE html> <html> <head> <html lang="ja"> <meta charset="utf-8"> <title>用語検索</title> <!-- Bootstrap CSS --> <meta name="viewport" content="width=device-width,initial-scale=1"> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous"> <link rel="shortcut icon" href="img\favicon.png"> <style> body { background: #f3f3f3; font-family: 'Noto Sans JP', sans-serif; } </style> </head> <body> <center> <div class="container mt-5 pt-5"> <div class="row"> <div class="col-md-6 offset-md-3"> <h3 class="mb-5 text-center">用語検索</h3> </div> </div> </div> <div class="mb-5"> <form action="" method="POST"> <div class="form-group col-5"> <input type="text" name="keyword" placeholder="単語を入力して下さい" class="form-control"/> </div> <div class="form-group col-5"> <input type="submit" value="検索" class="form-control"/> </div> </form> </div> <div class="col-xs-6 col-xs-offset-3"> <table class="table"> <thead> <tr> <th>用語</th> <th>意味</th> <th>種類</th> <th>使用例</th> </tr> </thead> <tbody> <tr> <?php $dsn = 'mysql:host=localhost;dbname=*****'; $username = 'root'; $password = '****'; if ($_POST) { try { $dbh = new PDO($dsn, $username, $password); $searchWord = $_POST['keyword']; if($searchWord==""){ echo "<td>用語を入力して下さい</td>"; } else{ $sql ="select * from lwolist where wordorigin like '".$searchWord."%'"; $sth = $dbh->prepare($sql); $sth->execute(); $result = $sth->fetchAll(); if($result){ foreach ($result as $row) { echo "<td>".$row['wordorigin']."</td><td>".$row['wordmeaning']."</td><td>".$row['wordtype']."</td><td>".$row['wordexample']."</td>"; } } else{ echo "<td>一致する用語が有りませんでした</td>"; } } }catch (PDOException $e) { echo "<p>Failed : " . $e->getMessage()."</p>"; exit(); } } ?> </tr> </tbody> </table> <div class="container mt-5 pt-5"> <div class="row"> <div class="col-md-6 offset-md-3"> <h3 class="mb-5 text-center">用語追加</h3> </div> </div> </div> <form action="add.php" method="post"> <div class="form-group col-5"> <input type="text" name="insertedword" placeholder="用語を半角英字で入力して下さい" class="form-control"/> </div> <div class="form-group col-5"> <input type="text" name="insertedmeaning" placeholder="用語の意味を入力して下さい" class="form-control"/> </div> <div class="form-group col-5"> <select name="insertedtype" class="form-control"> <option disabled selected value="用語の種類を選択して下さい">用語の種類を選択して下さい</option> <option value="種類1">種類1</option> <option value="種類2">種類2</option> <option value="種類3">種類3</option> <option value="種類4">種類4</option> </select> </div> <div class="form-group col-5"> <input type="text" name="insertedexample" placeholder="使用例を入力して下さい" class="form-control"/> </div> <div class="form-group col-5"> <input type="submit" value="追加" class="form-control"/> </div> </form> <?php add.phpのメッセージ出力結果を反映させたい場所です。 「3種の入力フォームと1種のドロップダウンリストから送信されてきた値が空でない場合にそれぞれの値をmySQLのデータベースに追加し、メッセージ(add.phpの24行目と33行目)を出力する」です。 ?> <br> <h7>Copyright © 2022 user</h7> <br> </center> </body> </html>
add.php↓
<?php if($_POST['insertedword'] != "" && $_POST['insertedmeaning'] != "" && $_POST['insertedtype'] != "" && $_POST['insertedexample'] != "") { try { //DB名、ユーザー名、パスワード $dsn = 'mysql:dbname=*****;host=*****'; $user = 'root'; $password = '****'; $insertedWord = $_POST['insertedword']; $insertedMeaning = $_POST['insertedmeaning']; $insertedType = $_POST['insertedtype']; $insertedExample = $_POST['insertedexample']; $PDO = new PDO($dsn, $user, $password); //MySQLのデータベースに接続 $PDO->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); //PDOのエラーレポートを表示 $sql = "INSERT INTO lwolist (wordorigin, wordmeaning, wordtype, wordexample) VALUES (:wordorigin, :wordmeaning, :wordtype, :wordexample)"; $stmt = $PDO->prepare($sql); $params = array(':wordorigin' => $insertedWord, ':wordmeaning' => $insertedMeaning, ':wordtype' => $insertedType, ':wordexample' => $insertedExample); $stmt->execute($params); echo "<center>用語「".$insertedWord."」に「".$insertedMeaning."」という意味の「".$insertedType."」が使用例「".$insertedExample."」としてデータベースに追加されました!</center>"; } catch (PDOException $e) { exit('データベースに接続できませんでした。' . $e->getMessage()); } } else { echo "<center>入力エラーが有りました</center>"; } ?>
お手数お掛けして申し訳ないのですがもしお時間が御座いましたらご教授宜しくお願い致します。

下記のような回答は推奨されていません。
このような回答には修正を依頼しましょう。
また依頼した内容が修正された場合は、修正依頼を取り消すようにしましょう。
2022/03/29 12:11