我正在尝试观察CDI Web应用程序的启动和关闭事件。我有一个ApplicationScoped bean来监听这些事件:
@ApplicationScoped
public class PrettyfacesStartupObserver
{
private static final Log LOGGER = LogFactory.getLog(PrettyfacesStartupObserver.class);
public PrettyfacesStartupObserver()
{
LOGGER.debug("\n\n\n\n\n\n\n\n\n\nconstructor");
}
public void onStartup(@Observes
AfterBeanDiscovery afterBeanDiscovery
)
{
LOGGER.debug("\n\n\n\n\n\n\n\n\n\nafter bean discover");
}
public void onStartup(@Observes
AfterDeploymentValidation afterDeploymentValidation
)
{
LOGGER.debug("\n\n\n\n\n\n\n\n\n\n\nafter deployment validation");
}
public void onShutdown(@Observes
BeforeShutdown beforeShutdown
)
{
LOGGER.debug("\n\n\n\n\n\n\n\n\n\n\nbefore shutdown:" + beforeShutdown);
}
我在日志中看不到任何内容。
我错过了什么?
答案 0 :(得分:14)
感谢Pete Muir,解决方案是实现Extension接口。一旦我这样做,再创建一个特殊的文件,它就完美无缺。
要记住的是,如果您想观察(或采取行动)容器事件,您必须实现扩展接口,因为它是一个特殊事件。
https://docs.jboss.org/weld/reference/latest/en-US/html/extend.html#d0e4984
沃尔特
答案 1 :(得分:7)
Walter White提到的“特殊档案”是:
META-INF/services/javax.enterprise.inject.spi.Extension
该文件应包含Extension类的完全限定名称。 即:
org.mydomain.extension.MyExtension