我有自己的用户类,它继承了奏鸣曲的 BaseUser (Sonata\UserBundle\Entity\BaseUser)
。
我的问题:如果我尝试使用现有电子邮件从奏鸣曲管理员创建用户,则会收到以下异常:
“无法创建对象:Application\Sonata\UserBundle\Entity\User”SQLSTATE[23505]:唯一违规:7 错误:重复键值违反唯一约束详细信息:键 (email_canonical)=(test@test.com) 已存在。
我尝试使用正确的使用语句按照某些文档和票证中的建议使用 UniqueEntity,但无济于事。
我在 Sonata admin 的其他实体上使用 UniqueEntity 注释没有问题,并且我在表单中收到一条很好的消息,通知用户已经有一个具有该名称/标题的实体,而不是异常。但是对于 User 实体,它的工作方式并不相同。
这就是我在 AppKernel 中注册奏鸣曲用户包的方式:
new Application\Sonata\UserBundle\ApplicationSonataUserBundle('FOSUserBundle')
扩展 FOSUserBundle
在自定义用户实体中使用语句(由 EasyExtends 包生成,只是我添加了一些自定义列和与其他实体的一对多关系,例如:项目):
namespace Application\Sonata\UserBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
use Sonata\UserBundle\Entity\BaseUser as BaseUser;
use Doctrine\Common\Collections\ArrayCollection;
use Symfony\Component\Validator\Constraints as Assert;
use Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity;
这是用户类的注释:
/**
* User
*
* @ORM\Table(name="fos_users")
* @ORM\Entity
* @UniqueEntity("username")
* @UniqueEntity("username_canonical")
* @UniqueEntity("email")
* @UniqueEntity("email_canonical")
*/
这是我对 sonata_user 的配置:
sonata_user:
security_acl: true
manager_type: orm
class:
user: Application\Sonata\UserBundle\Entity\User
group: Application\Sonata\UserBundle\Entity\Group
这是 fos_user 的配置:
fos_user:
db_driver: orm
firewall_name: admin, user
user_class: Application\Sonata\UserBundle\Entity\User
group:
group_class: Application\Sonata\UserBundle\Entity\Group
group_manager: sonata.user.orm.group_manager
service:
user_manager: sonata.user.orm.user_manager
我正在使用自定义管理类
parameters:
#use custom user admin class
sonata.user.admin.user.class: Application\Sonata\UserBundle\Admin\Model\UserAdmin
(我也尝试过使用默认的管理类)
这是我的奏鸣曲管理员配置:
sonata_admin:安全:处理程序:sonata.admin.security.handler.acl 标题:我的应用程序模板:布局:CoreBundle:Admin:standard_layout.html.twig
我也尝试用我自己的验证规则覆盖validation.yml/validation.xml 文件......但它们被忽略或类似的东西......
我没主意了。如果您能帮助我,我将不胜感激。