- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我设置了一个监听器类,我将在其中设置任何 doctrine prePersist 的 ownerid 列。我的 services.yml 文件看起来像这样......
services:
my.listener:
class: App\SharedBundle\Listener\EntityListener
arguments: ["@security.context"]
tags:
- { name: doctrine.event_listener, event: prePersist }
我的类(class)看起来像这样......
use Doctrine\ORM\Event\LifecycleEventArgs;
use Symfony\Component\Security\Core\SecurityContextInterface;
class EntityListener
{
protected $securityContext;
public function __construct(SecurityContextInterface $securityContext)
{
$this->securityContext = $securityContext;
}
/**
*
* @param LifecycleEventArgs $args
*/
public function prePersist(LifecycleEventArgs $args)
{
$entity = $args->getEntity();
$entityManager = $args->getEntityManager();
$entity->setCreatedby();
}
}
此操作的结果是以下错误。
ServiceCircularReferenceException: Circular reference detected for service "doctrine.orm.default_entity_manager", path: "doctrine.orm.default_entity_manager -> doctrine.dbal.default_connection -> my.listener -> security.context -> security.authentication.manager -> fos_user.user_manager".
我的假设是安全上下文已经被注入(inject)到链中的某处,但我不知道如何访问它。有任何想法吗?
最佳答案
我遇到了类似的问题,唯一的解决方法是在构造函数中传递整个容器(arguments: ['@service_container']
)。
use Doctrine\ORM\Event\LifecycleEventArgs;
use Symfony\Component\DependencyInjection\ContainerInterface;
class MyListener
{
protected $container;
public function __construct(ContainerInterface $container)
{
$this->container = $container;
}
// ...
public function prePersist(LifeCycleEventArgs $args)
{
$securityContext = $this->container->get('security.context');
// ...
}
}
关于php - 在 Symfony2 中将 SecurityContext 注入(inject)监听器 prePersist 或 preUpdate 以获取 createdBy 或 updatedBy 中的用户导致循环引用错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7561013/
我正在使用一种产品,几乎每个表都有这些列。作为开发人员,我们经常不得不加入用户表以获取创建记录的 ID,这只是代码中的一团糟。 我正在设计新产品并再次考虑这个问题。一定要这样吗?显然,知道谁创建了记录
我一直在思考这个问题一段时间,想不出一个可以接受的解决方案。我有一个计划变得非常大的应用程序。因此,我试图将其模块化。它基于MVC4。我还没有决定自己使用 ORM 或映射所有内容。我想要以下结构: -
我正在开发 JPA(Hibernate implementation of)、Spring 和 Stripes Web 应用程序。我有许多 JPA 实体,它们具有以下共同用于审计和查询目的的字段: c
我最近在我的团队中遇到了一场冲突,“某人”连续更新了,但没有人愿意接受是谁做的。我们总是有更新日期列、更新日期列、创建日期列和创建日期列,并且对数据库具有读写访问权限的人可以更新数据。 现在我的问题是
我正在使用移动后端启动器,并且我正在尝试在使用 secured by id 设置时更新实体。我不断收到错误 com.google.api.client.googleapis.json.GoogleJs
我设置了一个监听器类,我将在其中设置任何 doctrine prePersist 的 ownerid 列。我的 services.yml 文件看起来像这样...... services: my.lis
我设置了一个监听器类,我将在其中设置任何 doctrine prePersist 的 ownerid 列。我的 services.yml 文件看起来像这样...... services: my.lis
我是一名优秀的程序员,十分优秀!