予てから、LAMPを使ってPHPのCRUDアプリを作成してきておりました。
現在は一般ユーザーが閲覧できるページと、ログインページを経由しないとアクセスできないユーザー編集ページとに分けようとしているところです。
しかし、ログイン機能を実装したところ、ログインに直接関わってくるphpファイルのコードで「syntax error」が出てしまい、その記述をどう解消していいかが分からずにいます。
該当のコードは以下のとおりです。
// login.php <?php session_start(); // サーバー接続用のファイルを読み込む include('dbconnect.php'); $mail = htmlspecialchars($_POST['mail'], ENT_QUOTES, "UTF-8"); $sql = "SELECT * FROM users WHERE mail = :mail"; $stmt = $dbh->prepare($sql); $stmt->bindValue(':mail', $mail); $stmt->execute(); $member = $stmt->fetch(); //指定したハッシュがパスワードにマッチしているかチェック if (password_verify($_POST['pass'], $member['pass']) { //DBのユーザー情報をセッションに保存 $_SESSION['id'] = $member['id']; //←この「;」がおかしいと出る $_SESSION['name'] = $member['name']; //←とするならばここも $msg = 'ログインしました。'; $link = '<a href="index.php">ホーム</a>'; } else { $msg = 'メールアドレスもしくはパスワードが間違っています。'; $link = '<a href="login.php">戻る</a>'; } ?> <h1><?php echo $msg; ?></h1> <?php echo $link; ?>
<?php // dbconnect.php $host = 'localhost'; //ホスト名を入力して下さい。 $dbname = 'crud'; //データベースサーバー名を入力して下さい。 $username = 'root'; //ユーザーネームを入力して下さい。 $password = ''; //パスワードを入力して下さい(ない場合は入力不要)。 $dsn = "mysql:host={$host}; dbname={$dbname}; charset=utf8"; try { $dbh = new PDO($dsn, $username, $password); } catch (PDOException $e) { $msg = $e->getMessage(); }
login.phpのファイルでエラーの原因となっている「;」は、或いはそこを修正した後の周辺のコードのまとめ方としては、どう記述するのがふさわしいでしょうか。
ごく基礎的な内容かもしれませんが、畏れながら、ご回答お願いします。
回答2件
あなたの回答
tips
プレビュー