前提・実現したいこと
掲示板サイトを作成しておりフォーム入力後、書き込みをすると下記のエラーメッセージが表示されてしまいます。
エラーメッセージに表示されているon line 33とは該当のソースコードにも記載がある
「$stmt->bindParam(':name', $name, PDO::PARAM_STR);」
というコードです。
どなたかわかる方いればご教授お願いします。
発生している問題・エラーメッセージ
Fatal error: Uncaught Error: Call to a member function bindParam() on boolean in C:\xampp\htdocs\tennis\write.php:33 Stack trace: #0 {main} thrown in C:\xampp\htdocs\tennis\write.php on line 33
該当のソースコード→write.php(post)
<?php // データの受け取り $name = $_POST['name']; $title = $_POST['title']; $body = $_POST['body']; $pass = $_POST['pass']; // 必須項目チェック(名前か本文が空ではないか?) if ($name == '' || $body == ''){ header('Location: bbs.php'); // bbs.phpへ移動 exit(); // 終了 } // 必須項目チェック(パスワードは4桁の数字か?) if (!preg_match("/^[0-9]{4}$/", $pass)){ header('Location: bbs.php'); exit(); } // 名前をクッキーにセット setcookie('name', $name, time() + 60 * 60 * 24 * 30); // データベースに接続 $dsn = 'mysql:host=localhost;dbname=tennis;charset=utf8'; $user = 'tennisuser'; $password = 'password'; // tennisuserに設定したパスワード try { $db = new PDO($dsn, $user, $password); $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); // プリペアドステートメントを作成 $stmt = $db->prepare(" INSERT INTO bbs (name, title, body, date, pass) VALUES (:name, :title, :body, now(), :pass)" ); // パラメータを割り当て $stmt->bindParam(':name', $name, PDO::PARAM_STR); $stmt->bindParam(':title', $title, PDO::PARAM_STR); $stmt->bindParam(':body', $body, PDO::PARAM_STR); $stmt->bindParam(':pass', $pass, PDO::PARAM_STR); // クエリの実行 $stmt->execute(); // bbs.phpに戻る header('Location: bbs.php'); exit(); } catch(PDOException $e) { die ('エラー:' . $e->getMessage()); } ?>
bbs.php(get)
1<html> 2<head> 3 <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> 4 <title>交流サイト:掲示板</title> 5</head> 6<body> 7 <h1>掲示板</h1> 8 <p><a href="index.php">トップページに戻る</a></p> 9 <form action="write.php" method="post"> 10 <p>名前:<input type="text" name="name"></p> 11 <p>タイトル:<input type="text" name="title"></p> 12 <textarea name="body"></textarea> 13 <p>削除パスワード(数字4桁):<input type="text" name="pass"></p> 14 <p><input type="submit" value="書き込む"></p> 15 </form> 16</body> 17</html> 18
ご自身の環境のPHPのバージョンとどういう内容を入力して送信したかを質問本文に追記してください。
また既についた回答を参考に調整されたコードも別途ご提示ください。回答者さんの意図通りにできているかは「やってみました」だけでは分かりませんし、「それで実行して何が起きたか」は教えてもらいたいです。その結果を元に次の対策を考えるものなので。
回答1件
あなたの回答
tips
プレビュー