6

我今天一直在尝试使用 Symfony2 创建一个登录表单,用户可以使用他们的电子邮件地址和密码登录。我遇到了很多问题,最后意识到只有在我的实体类中有一个$username属性时它才会起作用。AdminUser我已经尝试在可能的情况下使用电子邮件而不是用户名,所以有人可以解释为什么$username需要或我哪里出错了?另外,在我的login.html.twig文件中,我仍在使用,_username而不是_email这有什么不同?我的代码如下(我删除了一些不适用的 getter 和 setter):

管理员用户实体:

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:假表达式:真

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 } 
4

4 回答 4

12

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

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

firewalls
    form_login:
        username_parameter: _username

可能你应该看看安全配置文件

于 2013-03-05T16:16:02.817 回答
2
firewalls:
 main:
  form_login: 
    username_parameter: _email

您的所有代码都是正确的,您只需要在 security.yml 文件中进行一些更改。只需添加用户名参数。

于 2015-02-17T04:52:59.287 回答
0

尝试使用FOSUserBundle

它有一个默认功能,用户可以使用他们的用户名或电子邮件字段登录。

于 2013-03-05T16:33:27.587 回答
0

这有点骇人听闻,但您可以从注册表单中删除用户名字段,并在您的用户实体中执行以下操作:

public function setEmail($email) 
{
    $this->email = $email;
    $this->username = $email;
}
于 2013-01-10T22:54:48.627 回答