所以我使用带有LDAP的FOSUserBundle作为我的身份验证方法,并且我想知道是否有办法删除/忽略password
实体的FOSUser
字段?
我意识到删除可能并不理想(如果它与内部逻辑相混淆),但是从未使用过该列,并且当我从中创建FOSUsers
时,我不得不填写它夹具:
$user = new FOSUser();
$user->setDn($item["dn"]);
$user->setEnabled(1);
$user->setUsername($item["samaccountname"][0]);
$user->setUsernameCanonical(strtolower($item["samaccountname"][0]));
$user->setEmail($item["mail"][0]);
$user->setEmailCanonical(strtolower($item["mail"][0]));
$user->setDepartment($ldap_groups[$matches[1]]);
$user->setDepartmentDn($group);
$user->setPassword('blank'); // Is there away to avoid this?
$manager->persist($user);
答案 0 :(得分:1)
您实际上可以删除密码,但您必须保留UserInterface中定义的getPassword()
。如果你想保留它,例如当您允许多种登录类型时,您将再次需要它。我建议将字段设置为可空。如果您使用注释,就像向列中添加nullable=true
一样简单:
/**
* @ORM\Column(type="string", name="password", nullable=true)
*/
答案 1 :(得分:0)
因此,要覆盖列原则允许Inheritance Mapping:
/**
* @ORM\Entity
* @ORM\Table(name="fos_user")
* @ORM\AttributeOverrides({
* @ORM\AttributeOverride(name="password",
* column=@ORM\Column(
* name = "password",
* type = "string",
* nullable=true
* )
* )
* })
*/
class FOSUser extends BaseUser implements LdapUserInterface
{
// Extended logic.
}
密码字段仍位于BaseUser
,但被@ORM\AttributeOverride
注释覆盖。