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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

ログイン

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

Q&A

解決済

1回答

1166閲覧

データベースに登録されているかどうかを確認することでログイン機能を実装したい。

TIIR

総合スコア4

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

ログイン

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

0グッド

0クリップ

投稿2020/08/05 14:03

編集2020/08/05 14:04

ログインをしたいです。
前提:
mailとpasswordは前の画面からpostされてきます。

問題のあるコードは以下になります。

PHP

1<!DOCTYPE html> 2<head> 3 <meta charset="UTF8"> 4 <title>Training</title> 5</head> 6<body> 7 <?php 8 require_once('common.php'); 9 $post=sanitize($_POST); 10 $mail = $post['mail']; 11 $pass = $post['password']; 12 $dsn='mysql:dbname=muscle;host=localhost;charset=utf8'; 13 $user='root'; 14 $password=''; 15 $dbh=new PDO($dsn, $user, $password); 16 $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); 17 18 $sql='SELECT * FROM user_data WHERE mail= :mail AND password= :password limit 1'; 19 20 $stmt=$dbh->prepare($sql); 21 22 $stmt->execute(array(':mail' => $mail)); 23 $stmt->execute(array(':password' => md5($pass))); 24 $rec = $stmt->fetch(PDO::FETCH_ASSOC); 25 26 if($rec > 0){ 27 $code = $rec['code']; 28 session_start(); 29 $_SESSION['user_login']=1; 30 $_SESSION['user_code']=$code; 31 $_SESSION['user_name']=$name; 32 header("Location: member_training_data.php"); 33 } 34 else{ 35 print'メールアドレスもしくはパスワードが間違っています。'; 36 print'<input onclick="history.back()" value="戻る>'; 37 print'<a href="member_registration.html">初めての方はこちら</a>'; 38 } 39 ;?> 40</body> 41</html>

エラーは、この通り。

Fatal error: Uncaught PDOException: SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens in C:\xampp\htdocs\php_study_site\login_check.php:22 Stack trace: #0 C:\xampp\htdocs\php_study_site\login_check.php(22): PDOStatement->execute(Array) #1 {main} thrown in C:\xampp\htdocs\php_study_site\login_check.php on line 22

22行目は以下です。

PHP

1 $stmt->execute(array(':mail' => $mail));

尚、common.php の内容は、

PHP

1 function sanitize($before){ 2 foreach($before as $key => $value){ 3 $after[$key]=htmlspecialchars($value, ENT_QUOTES, 'UTF-8'); 4 } 5 return $after; 6 }

です。ここは関係ないかと思います。

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2020/08/05 14:56

https://teratail.com/questions/282377 が解決していないようですし、同じ内容をもう一度質問を起こすのは嫌われますよ。 一つ一つの質問は再度編集することができますので、求められた追加情報を質問文中に反映するよう、切にお願いいたします。
TIIR

2020/08/06 00:09

あ、そうなんですね、同じ内容でエラー起きてるんですね。ありがとうございます。 はい、気を付けます。
guest

回答1

0

ベストアンサー

エラーメッセージの通りです。

execute のマニュアルを確認してください。
PDOStatement::execute

PDO を使用する際のテンプレートを用意しているので、そちらを参考に修正されても良いかと。
PHP で MySQL 接続時に必要な知識(最小限版)

また、設計から使用する関数の選択まで全体的におかしいので、教本を変えた方がよいです。

投稿2020/08/05 21:29

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

TIIR

2020/08/06 00:10

教本を変えた方がよいです。 →了解しました。使用する関数の選択にも優劣があるんですね。頂いたリンク、参照します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問