为了账号安全,请及时绑定邮箱和手机立即绑定

Symfony 身份验证总是返回“Invalid Credentials”

Symfony 身份验证总是返回“Invalid Credentials”

PHP
繁星coding 2022-07-09 18:22:28
我正在尝试使用 Symfony 实现身份验证。不幸的是,无论我尝试什么,我都会一遍又一遍地收到错误“ Invalid Credentials ”。我读过其他文章,但没有一篇派上用场。这可能是什么原因,我该如何解决?我尝试修改 getUsername() 以返回电子邮件而不是用户名,但它没有用。我检查了我的注册过程,确定哈希是否正确,将 password_verify 的结果转储为纯密码和来自数据库(这是真的)等。我相信我做错了什么。安全性.yml:security:    role_hierarchy:    encoders:        AppBundle\Entity\User: bcrypt    # https://symfony.com/doc/current/security.html#b-configuring-how-users-are-loaded    providers:        db_provider:            entity:                class: AppBundle\Entity\User                property: email    firewalls:        dev:            pattern: ^/(_(profiler|wdt)|css|images|js)/            security: false        main:            pattern: ^/            provider: db_provider            anonymous: ~            form_login:                username_parameter: _email                check_path: security_login                login_path: security_login                default_target_path: homepage                always_use_default_target_path: true                csrf_token_generator: security.csrf.token_manager            logout:                path: security_logout                target: security_login    access_control:        # this is a catch-all for the admin area        # addition security lices in the controllers        # - { path: '^/(%locale%)/admin', roles: ROLE_ADMIN        # - { path: '^/ucp', roles: [IS_AUTHENTICATED_FULLY] }login.html.twig<form name="authenticate" action="{{ path('security_login') }}" method="post" class="loginForm" id="loginForm">    <div class="form-group">        <input type="email" class="form-control" name="_email" value="{{ last_username }}" id="email" placeholder="Имейл адрес"/>    </div>    <div class="form-group">        <input type="password" class="form-control" name=_password" id="password" placeholder="Парола"/>    </div>    <input type="hidden" name="_csrf_token" value="{{ csrf_token('authenticate') }}">    <div class="text-center"><button type="submit" id="loginButton">Log in</button></div></form>
查看完整描述

2 回答

?
千万里不及你

TA贡献1784条经验 获得超9个赞

哦,天哪,我已经解决了……不幸的是,这是一个令人尴尬的错误……我刚刚错过了密码名称属性的第一个引号,它是 name=_password”



查看完整回答
反对 回复 2022-07-09
?
哔哔one

TA贡献1854条经验 获得超8个赞

您可以使用UserPasswordEncoderInterface清楚地散列您的密码,例如:


.....

use Symfony\Component\Security\Core\Encoder\UserPasswordEncoderInterface;

......


class UserService implements UserServiceInterface

{

    private $userPasswordEncoderInterface;

    private $entityManager;


    public function __construct(

      UserPasswordEncoderInterface $userPasswordEncoderInterface,

      EntityManagerInterface $entityManager)

    {

        $this->userPasswordEncoderInterface = $userPasswordEncoderInterface;

        $this->entityManager = $entityManager;

    }


    public function save(User $user): Response

    {

        $passwordHash = $this->userPasswordEncoderInterface->encodePassword($user, $user->getPassword());

        $user->setPassword($passwordHash);


        $this->entityManager->persist($user);

        $this->entityManager->flush();


        return new Response('password encoded');

    }

}


查看完整回答
反对 回复 2022-07-09
  • 2 回答
  • 0 关注
  • 920 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信