authentication - 使用电子邮件而不是用户名的Symfony2身份验证/登录

标签 authentication symfony login doctrine entity

今天,我一直在尝试使用Symfony2创建一个登录表单,用户可以在其中使用其电子邮件地址和密码登录。我遇到了很多问题,最后意识到,只有当我在$username实体类中具有AdminUser属性时,它才有效。我尝试过使用电子邮件代替用户名,所以有人可以解释为什么需要$username或我出了什么问题吗?另外,在我的login.html.twig文件中,如果仍然有区别,我仍在使用_username而不是_email?我的代码如下(我删除了一些不适用的 setter和getter ):

AdminUser实体:

namespace XXX\WebsiteBundle\Entity;

use Symfony\Component\Security\Core\User\UserInterface;
use Doctrine\ORM\Mapping as ORM;

/**
* AdminUser
*
* @ORM\Table(name="admin_user",indexes={@ORM\Index(name="indexes", columns={"deleted"})})
* @ORM\Entity
* @ORM\HasLifecycleCallbacks()
*/
class AdminUser implements UserInterface
{
/**
 * @var integer
 *
 * @ORM\Column(name="id", type="integer")
 * @ORM\Id
 * @ORM\GeneratedValue(strategy="AUTO")
 */
private $id;

/**
 * @var string
 *
 * @ORM\Column(name="name", type="string", length=45)
 */
private $name;

/**
 * @var string
 *
 * @ORM\Column(name="email", type="string", length=45, unique=true)
 */
private $email;

/**
 * @var string
 *
 * @ORM\Column(name="salt", type="string", length=255)
 */
private $salt;

/**
 * @var string
 *
 * @ORM\Column(name="password", type="string", length=255)
 */
private $password;

/**
 * @var integer
 *
 * @ORM\Column(name="enabled", type="integer", options={"default" = 0})
 */
private $enabled;

/**
 * @var string[] $roles
 *
 * @ORM\Column(name="roles", type="array")
 */
private $roles = array();

private $username;


/**
 * Gets the username.
 *
 * @return string The username.
 */
public function getUsername()
{
    return $this->email;
}

/**
 * Erases the user credentials.
 */
public function eraseCredentials()
{

}


/**
 * Returns the roles granted to the user.
 *
 * <code>
 * public function getRoles()
 * {
 *     return array('ROLE_USER');
 * }
 * </code>
 *
 * Alternatively, the roles might be stored on a ``roles`` property,
 * and populated in any number of different ways when the user object
 * is created.
 *
 * @return Role[] The user roles
 */
public function getRoles() {
    return $this -> roles;
}

/**
 * Set the roles of the user
 *
 * @var string[] $roles
 *
 * @return \XXX\WebsiteBundle\Entity\User this
 */
public function setRoles(array $roles) {
    $this -> roles = $roles;

    return $this;
}



} 

我的security.yml文件是:

jms_security_extra: secure_all_services: false expressions: true


security:
encoders:
    XXX\WebsiteBundle\Entity\AdminUser: sha512

role_hierarchy:
    ROLE_ADMIN:       ROLE_USER
    ROLE_SUPER_ADMIN: [ROLE_USER, ROLE_ADMIN, ROLE_ALLOWED_TO_SWITCH]

providers:
    main_provider:
        entity: { class: XXX\WebsiteBundle\Entity\AdminUser, property: email }

firewalls:
    dev:
        pattern:  ^/(_(profiler|wdt)|css|images|js)/
        security: false

    admin_firewall:
        pattern:  ^/admin.*
        anonymous: ~
        form_login:
            login_path:  /admin/login
            check_path:  /admin/login_check

access_control:
    - { path: ^/admin/login.*, roles: IS_AUTHENTICATED_ANONYMOUSLY }
    - { path: ^/admin.*, roles: ROLE_ADMIN } 

最佳答案

我想您应该使用电子邮件更改属性,还可以通过以下任何方式更改_username参数:

entity:
            entity:
                class:               SecurityBundle:User
                property:            username


firewalls
    form_login:
        username_parameter: _username

可能是您应该看看security configuration document

关于authentication - 使用电子邮件而不是用户名的Symfony2身份验证/登录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14267581/

相关文章:

使用 Django 服务器主机名和监听端口作为 redirect_uri 的 Python-social-auth

php - Symfony2 - Doctrine - 有没有办法在一行中保存实体?

php - 如何使用Symfony Mailer组件禁用 "verify_peer"?

asp.net - 如何在不使用 MembershipProvider 的情况下使用 ASP.NET 登录控件?

security - 如何检测登录是否可疑?

authentication - 将 AWS Cognito 用户迁移到 Auth0

javascript - 通过 REST 使用 Web 服务,并使用完整的 JavaScript 进行身份验证

tomcat - 如何检查 FORM Realm 身份验证是否失败?

php - Symfony2 包内路由

php - 使用PDO登录时,PHP检查数据库中的用户名和密码