🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

1回答

1393閲覧

データベースの接続エラーの原因が分かりません

imada

総合スコア4

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2019/09/06 13:00

編集2019/09/06 13:09

前提・実現したいこと

PHPの新規登録フォームに入力したデータをphpmyadminデータベースに挿入したい。

発生している問題・エラーメッセージ

データベースエラーの表示が出ます。多分データベースに接続ができていません。

該当のソースコード

<?php session_start(); $db['host'] = "localhost"; // DBサーバのURL $db['user'] = "suzuki"; // ユーザー名 $db['pass'] = "love"; // ユーザー名のパスワード $db['dbname'] = "teacher"; // データベース名 // エラーメッセージの初期化 $errorMessage = ""; // ログインボタンが押された場合 if (isset($_POST["login"])) { // 1. ユーザIDの入力チェック if (empty($_POST["userid"])) { // emptyは値が空のとき $errorMessage = 'ユーザーIDが未入力です。'; } else if (empty($_POST["password"])) { $errorMessage = 'パスワードが未入力です。'; } if (!empty($_POST["userid"]) && !empty($_POST["password"])) { // 入力したユーザIDを格納 $userid = $_POST["userid"]; // 2. ユーザIDとパスワードが入力されていたら認証する $dsn = sprintf('mysql: host=%s; dbname=%s; charset=utf8', $db['host'], $db['dbname']); // 3. エラー処理 try { $pdo = new PDO($dsn, $db['user'], $db['pass'], array(PDO::ATTR_ERRMODE=>PDO::ERRMODE_EXCEPTION)); $stmt = $pdo->prepare('SELECT * FROM userData WHERE name = ?'); $stmt->execute(array($userid)); $password = $_POST["password"]; if ($row = $stmt->fetch(PDO::FETCH_ASSOC)) { if (password_verify($password, $row['password'])) { session_regenerate_id(true); // 入力したIDのユーザー名を取得 $id = $row['id']; $sql = "SELECT * FROM userData WHERE id = $id"; //入力したIDからユーザー名を取得 $stmt = $pdo->query($sql); foreach ($stmt as $row) { $row['name']; // ユーザー名 } $_SESSION["NAME"] = $row['name']; header("Location: Main.php"); // メイン画面へ遷移 exit(); // 処理終了 } else { // 認証失敗 $errorMessage = 'ユーザーIDあるいはパスワードに誤りがあります。'; } } else { // 4. 認証成功なら、セッションIDを新規に発行する // 該当データなし $errorMessage = 'ユーザーIDあるいはパスワードに誤りがあります。'; } } catch (PDOException $e) { $errorMessage = 'データベースエラー'; //$errorMessage = $sql; // $e->getMessage() でエラー内容を参照可能(デバッグ時のみ表示) // echo $e->getMessage(); } } } ?> <form id="loginForm" name="loginForm" action="" method="POST"> <fieldset> <div><font color="#ff0000"><?php echo htmlspecialchars($errorMessage, ENT_QUOTES); ?></font></div> <label for="userid">ユーザーID</label><input type="text" id="userid" name="userid" placeholder="ユーザーIDを入力" value="<?php if (!empty($_POST["userid"])) {echo htmlspecialchars($_POST["userid"], ENT_QUOTES);} ?>"> <br> <label for="password">パスワード</label><input type="password" id="password" name="password" value="" placeholder="パスワードを入力"> <br> <input type="submit" id="login" name="login" value="ログイン"> </fieldset> </form> <br> <form action="SignUp.php"> </form> </div> </div> <div id="footer"> </div> </div> </body> </html>

試したこと

ユーザー名やパスワードを変えてみたり、データベースを変更してみたりしましたが、何度やっても接続できません。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

mepon

2019/09/06 13:55

せっかくcatchしてるのにエラーメッセージ握りつぶしたら意味ないですよね。 エラーメッセージ表示させてみればよいだけでは?
m.ts10806

2019/09/06 21:20

「デバッグ時のみ表示」とコメント書かれてますが、学習期、業務なら本番以外なら常に表示させておいて良いと思います。 特に質問するのであれば絶対に必要です。エラーメッセージは問題解決には不可欠な要素です
退会済みユーザー

退会済みユーザー

2019/09/07 00:36

業務でも消しちゃダメだろ DB接続エラーは
m.ts10806

2019/09/07 03:29

asahina1979さん 画面表示の話ですので。ログ出力は必須です。
guest

回答1

0

データベースの接続エラーの原因が分かりません

エラー出してないとわかるようにはなりません。

php

1 } catch (PDOException $e) { 2 $errorMessage = 'データベースエラー'; 3 //$errorMessage = $sql; 4 // $e->getMessage() でエラー内容を参照可能(デバッグ時のみ表示) 5 // echo $e->getMessage(); 6 }

php

1 } catch (PDOException $e) { 2 die(var_dump($e)); 3 }

学習時期や本番前の開発時期であれば必ず捕捉したExceptionは出力するようにしましょう。
さいあく、json_encode()したものをログファイルに書き出すのでも良いです(本番中はログファイル書き出しは必須)

phpmyadminデータベースに挿入したい。

phpMyAdminはデータベースではなくデータベースを操作するためのツールの1つにすぎません。
MySQLまたはMariaDBがデータベースです。

気になるところ。

$dsn = sprintf('mysql: host=%s; dbname=%s; charset=utf8', $db['host'], $db['dbname']);

dsnって区切りの:とか;はスペース開けたらだめだった気がします。
PDO:接続、および接続の管理
それで接続できないって質問を見たことがあります。

参考まで。

投稿2019/09/07 00:02

m.ts10806

総合スコア80875

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問