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

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

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

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

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

PHP

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

Q&A

解決済

1回答

2522閲覧

データベースに入れた値でpassword_verifyを使って比較したい

退会済みユーザー

退会済みユーザー

総合スコア0

MySQL

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

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

PHP

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

0グッド

0クリップ

投稿2018/04/10 05:22

PHP,MySQL初学者です。
データベースにハッシュ化したパスワードを入れました。
SQLで値を取得して、認証したいのですが持ってきた値をどのように書けばいいのかわかりません。
色々おかしいところも多いと思いますが、教えていただけると助かります。

php

1<?php 2 require_once ''; 3 4try { 5 $dbh = new PDO($dns , $user , $pass); //データベースに接続 6 $dbh->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); //PDPクラスのエミュレーションを無効にする 7 $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);//Exceptionを投げる 8 $sql = "SELECT * FROM user_date"; 9 $stmt = $dbh->prepare($sql); //$stmtでデータベースにSQLをセット 10 $stmt->execute(); 11 12 if (password_verify($_POST['password'],){ 13 echo '認証成功'; 14 }else{ 15 echo '認証失敗'; 16 } 17 18 $dbh = null; 19 echo "ログイン完了しました";//ここに確認画面 20} catch (Exception $e) { 21 echo "エラー発生: " . htmlspecialchars($e->getMessage(),ENT_QUOTES, 'UTF-8') . "<br>"; 22 echo "<a href='logo.html'>ログイン画面に戻る</a>"; 23 die(); 24}

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

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

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

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

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

guest

回答1

0

ベストアンサー

毎度のことですがマニュアルで使い方を確認してから使いましょう。

毎度のことですが、マニュアルを確認したような使い方がされていません。

第2引数はマニュアルより

password_hash() が作ったハッシュ。

「データベースにハッシュ化したパスワードを入れました。」のであれば、そのハッシュ化したパスワードが最初のSELECTで取得できているはずですよね?

投稿2018/04/10 05:33

m.ts10806

総合スコア80850

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

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

退会済みユーザー

退会済みユーザー

2018/04/10 05:40

読んでみて、この関数が使えそうに思ったのですが使い方が間違ってるんですね。取得してきて$stmtにハッシュ化した値は入っていると思うのですが、そこからよく記述の方法がわかりませんでした。
m.ts10806

2018/04/10 05:43

間違っている というより足りてません。 > if (password_verify($_POST['password'],){ 第2引数が入っていないですし、それ以前にifの閉じかっこがありません。 シンタックスエラー出てるはずです。 $stmt->execute(); までは良いので、あとはデータを取得してきて取得してきたデータを第2引数に指定すれば良いと思います。 ※あくまでpassword_hash()で作ったハッシュ値が入っているのが前提です
m.ts10806

2018/04/10 05:47

あと前も見たかもしれませんけど 冒頭の require_once ''; って何のために入れているのでしょうか? 特に何も読み込むことがないのであれば不要な記述ではないでしょうか。
退会済みユーザー

退会済みユーザー

2018/04/10 05:53

第二引数の書き方がよくわからず記述途中でした。データの取得方法がわかっていませんでした。
退会済みユーザー

退会済みユーザー

2018/04/10 05:55

require_once '';はデータベースに繋げるためのhost名やデータベース名、ユーザー名、パスワードなど記述して呼び出しています。
m.ts10806

2018/04/10 05:56

「これ使いたい」のは構わないのですが、 その使うための準備ができていないのであれば、準備を優先すべきです。 物事には手順があるので、具体的な手順を考えて、1つずつ実行してくようにしてください。
m.ts10806

2018/04/10 05:58 編集

> require_once '';はデータベースに繋げるためのhost名やデータベース名、ユーザー名、パスワードなど記述して呼び出しています。 なるほど。であれば '' と空にするのではなく、コードの記述をそのまま置けば良いとおもいますよ。 内容を書けということではないですし、そこを空にされると回答者の混乱を招きます。(内容を書くことがあっても hogehoge とか sample とか test とか適当な文字でマスクすれば良い話です)
退会済みユーザー

退会済みユーザー

2018/04/10 06:00

はい!おそらくわからないことが多すぎるので、1つ1つ理解していこうと思います。毎度細かく回答していただいてありがとうございます。
退会済みユーザー

退会済みユーザー

2018/04/10 06:01

なるほど!すいません、関係ないと思い消してました。これからは記述します!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問