質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.47%
PHP

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

ログイン

ログインは、ユーザーがコンピューターシステムにアクセスするプロセスの事を呼びます。

Q&A

1回答

780閲覧

phpでのログインページがうまく動かない

watta_00

総合スコア16

PHP

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

ログイン

ログインは、ユーザーがコンピューターシステムにアクセスするプロセスの事を呼びます。

0グッド

0クリップ

投稿2019/12/11 14:36

ログインページの動作がうまくいきません。
データベースに該当するデータがあるはずなのに該当データなしと表示されてしまいます。
原因がわからなく、つまずいています。

php

1<?php 2ini_set('display_errors', 1); 3ini_set('error_reporting', E_ALL); 4require 'password.php'; // password_verfy()はphp 5.5.0以降の関数のため、バージョンが古くて使えない場合に使用 5// セッション開始 6session_start(); 7 8$db['host'] = "localhost"; // DBサーバのURL 9$db['user'] = "root"; // ユーザー名 10$db['pass'] = "root"; // ユーザー名のパスワード 11$db['dbname'] = "loginManagement"; // データベース名 12 13// エラーメッセージの初期化 14$errorMessage = ""; 15 16// ログインボタンが押された場合 17if (isset($_POST["login"])) { 18 // 1. ユーザIDの入力チェック 19 if (empty($_POST["userid"])) { // emptyは値が空のとき 20 $errorMessage = 'ユーザーIDが未入力です。'; 21 } else if (empty($_POST["password"])) { 22 $errorMessage = 'パスワードが未入力です。'; 23 } 24 25 if (!empty($_POST["userid"]) && !empty($_POST["password"])) { 26 // 入力したユーザIDを格納 27 $userid = $_POST["userid"]; 28 29 // 2. ユーザIDとパスワードが入力されていたら認証する 30 $dsn = sprintf('mysql: host=%s; dbname=%s; charset=utf8', $db['host'], $db['dbname']); 31 32 // 3. エラー処理 33 try { 34 $pdo = new PDO($dsn, $db['user'], $db['pass'], array(PDO::ATTR_ERRMODE=>PDO::ERRMODE_EXCEPTION)); 35 36 $stmt = $pdo->prepare('SELECT * FROM userData WHERE name = ?'); 37 $stmt->execute(array($userid)); 38 39 $password = $_POST["password"]; 40 41 if ($row = $stmt->fetch(PDO::FETCH_ASSOC)) { 42 if (password_verify($password, $row['password'])) { 43 session_regenerate_id(true); 44 45 // 入力したIDのユーザー名を取得 46 $id = $row['id']; 47 $sql = "SELECT * FROM userData WHERE id = $id"; //入力したIDからユーザー名を取得 48 $stmt = $pdo->query($sql); 49 foreach ($stmt as $row) { 50 $row['name']; // ユーザー名 51 } 52 $_SESSION["NAME"] = $row['name']; 53 header("Location: Main.php"); // メイン画面へ遷移 54 exit(); // 処理終了 55 } else { 56 // 認証失敗 57 $errorMessage = '(認証失敗)ユーザーIDあるいはパスワードに誤りがあります。'; 58 } 59 } else { 60 // 4. 認証成功なら、セッションIDを新規に発行する 61 // 該当データなし 62 $errorMessage = '(該当データなし)ユーザーIDあるいはパスワードに誤りがあります。'; 63 } 64 } catch (PDOException $e) { 65 $errorMessage = 'データベースエラー'; 66 $errorMessage = $sql; 67 //$e->getMessage(); でエラー内容を参照可能(デバッグ時のみ表示) 68 echo $e->getMessage(); 69 } 70 } 71} 72?> 73<!DOCTYPE html> 74<html lang="ja"> 75 <head> 76 <meta charset="utf-8"> 77 <meta http-equiv="X-UA-Compatible" content="IE=edge"> 78 <meta name="viewport" content="width=device-width, initial-scale=1"> 79 <title>Java学習</title> 80 <!-- BootstrapのCSS読み込み --> 81 <link href="css/bootstrap.css" rel="stylesheet"> 82 <!-- jQuery読み込み --> 83 <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script> 84 <!-- BootstrapのJS読み込み --> 85 <script src="js/bootstrap.min.js"></script> 86 </head> 87 <body> 88 <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.0.8/css/all.css"> 89 <nav class="navbar navbar-expand-lg navbar-dark bg-dark"> 90 <a class="navbar-brand" href="#">Java学習</a> 91 <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation"> 92 <span class="navbar-toggler-icon"></span> 93 </button> 94 95 <div class="collapse navbar-collapse" id="navbarSupportedContent"> 96 <!-- メニュー部分--> 97 <ul class="navbar-nav mr-auto"> 98 <li class="nav-item active"> 99 <a class="nav-link" href="index.html">ホーム<span class="sr-only">(current)</span></a> 100 </li> 101 <li class="nav-item"> 102 <a class="nav-link" href="menu.html">学習状況</a> 103 </li> 104 <li class="nav-item dropdown"> 105 <a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"> 106 Dropdown 107 </a> 108 <div class="dropdown-menu" aria-labelledby="navbarDropdown"> 109 <a class="dropdown-item" href="#">Action</a> 110 <a class="dropdown-item" href="#">Another action</a> 111 <div class="dropdown-divider"></div> 112 <a class="dropdown-item" href="#">Something else here</a> 113 </div> 114 </li> 115 <li class="nav-item"> 116 <a class="nav-link disabled" href="#">Disabled</a> 117 </li> 118 </ul> 119 <ul class="navbar-nav"> 120 <li class="nav-item"> 121 <a class="nav-link" href="../login/Login.php">ログイン</a> 122 </li> 123 </ul> 124 <!-- フォームを削除 --> 125 </div> 126 </nav> 127 <br><br><br> 128 <div class="container"> 129 <div class="row justify-content-center"> 130 <aside class="col-sm-4"> 131 <div class="card"> 132 <article class="card-body"> 133 <a href="Signup.php" class="float-right btn btn-outline-primary">新規登録</a> 134 <form id="loginForm" name="loginForm" action="" method="POST"> 135 <fieldset> 136 <h4 class="card-title mb-4 mt-1">Sign in</h4> 137 <div><font color="#ff0000"><?php echo htmlspecialchars($errorMessage, ENT_QUOTES); ?></font></div> 138 <label for="userid">ユーザーID</label> 139 <input type="text" id="userid" name="userid" placeholder="ユーザーIDを入力" value="<?php if (!empty($_POST["userid"])) {echo htmlspecialchars($_POST["userid"], ENT_QUOTES);} ?>"> 140 <br> 141 <label for="password">パスワード</label><input type="password" id="password" name="password" value="" placeholder="パスワードを入力"> 142 <br> 143 <input type="submit" id="login" name="login" value="ログイン"> 144 </fieldset> 145 </form> 146 </article> 147 </div> 148 </aside> 149 </div> 150 </div> 151 </body> 152</html>

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

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

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

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

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

m.ts10806

2019/12/12 00:36

うまくいきませんというのは誰にも何も伝えない表現なので極力避けてください
guest

回答1

0

nameに対してuserid当てにいってますけど本当にこれで正しくとれるんですか?

というのは

データベースに該当するデータがあるはず

というのは質問者さんの思い込みの可能性もあるのですけど
コードだけ提示されても誰もそれを「データはあるよ」と断定できないからです。
現状のコードだけで言えるのは一行目に書いた通り。
Exception拾ってないなら接続はできている「だろう」くらいです。
他者に提示すべき情報が足りていないのでここまでです。

投稿2019/12/12 00:44

編集2019/12/12 00:56
m.ts10806

総合スコア80852

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問