Laravel 5.3アプリに対してDoctrine 2 Authを設定しようとしています。私はLaravelでAuthコントローラを生成していますので、自分のカスタム実装ではありません。私はいくつかの小さな変更を加えました(つまり、ユーザーをDoctrineを使ってデータベースに保存するため)、ログインしようとすると登録が失敗してしまいます。Laravel認証hasValidCredentialsに失敗しました
Iデバッガとを介して強化していると、それは、以下に詳述するように一貫して(ベンダー/ laravel /フレームワーク/ SRC /を照らし/ AUTH/SessionGuard.phpに位置する)機能hasValidCredentialsに失敗しているように見える:
/**
* Check the given plain value against a hash.
*
* @param string $value
* @param string $hashedValue
* @param array $options
* @return bool
*/
public function check($value, $hashedValue, array $options = [])
{
if (strlen($hashedValue) === 0) {
return false;
}
return password_verify($value, $hashedValue);
}
$値= "テスター";次のように参照するために
、$値と$ HASHEDVALUEのための私の値は、
$ hashedValue = "$ 2y $ 10 $ ZSLRE3LAVA8myaH8mu6TNeumQxHdmKRbv/zZdFQeDujZ8JolshTOu";
私の最後のXDebugセッションごとのような変数のスクリーンショットは、変数の正確な種類を示しています。
$ HASHEDVALUEは、パスワードの(bcryptのを使用して)暗号化されたバージョンである「をテスター"したがって、資格情報が100%正しいことがわかりますが、実行がpassword_verifyになると、常にfalseに評価され、hasValidCredentialsのチェックに失敗します。
私のデータベースに次のように私は私のユーザーを格納しています:
だから私は、ハッシュされたパスワードは、十分な長さで、データベースに格納されていることを知っています。 $ hashedValueが二重引用符で返されていることがわかりましたが、これは問題になりますか?
セッションガードクラスの試行機能は常に失敗するため、ログインできません。hasValidCredentialsは常にfalseを返すため、常に失敗します。資格情報が正確であるため、私はかなり困惑しています。
誰かがこれを解決する方法に関するアイデアを持っているのだろうか?
おかげ
以下の評価結果がtrueのようだ: 'password_verify( '秘密のパスワード'、 '$ 2Y $ 10 $ EnIi90KP.0BqCVJgK21BrO3xzArxCZaiAPaUebCw.K2Xw71QOCZv2');' – liamjnorman
は私のアプリのキーはbase64エンコードであることに注意してください。それはまた、ハッシュを生成する際に問題を引き起こす可能性がありますか? – liamjnorman