Servlet过滤器中的CDI注入过滤器Tomcat 7.0.50

时间:2018-02-26 14:03:20

标签: jsf tomcat7 cdi servlet-filters weld

我想按照https://stackoverflow.com/a/7815328/802058中的描述将bean注入servlet过滤器,但它对我不起作用。我的配置是:

@FacesConfig(
    version = Version.JSF_2_3
)
@Named
@SessionScoped
public class FooBean implements Serializable {

@WebFilter("/foo.xhtml")
public class FooFilter implements Filter {
    @Inject
    private FooBean fooBean;

WEB-INF
    lib
        javax.faces-2.3.0.jar
        omnifaces-1.14.1.jar
        weld-servlet-shaded-3.0.2.Final.jar
beans.xml (empty)

启动后来自Tomcat的错误消息:

INFORMATION: Starting Servlet Engine: Apache Tomcat/7.0.50
Feb 26, 2018 2:41:37 PM org.jboss.weld.environment.servlet.EnhancedListener onStartup
INFO: WELD-ENV-001008: Initialize Weld using ServletContainerInitializer
Feb 26, 2018 2:41:37 PM org.jboss.weld.bootstrap.WeldStartup <clinit>
INFO: WELD-000900: 3.0.2 (Final)
Feb 26, 2018 2:41:38 PM org.jboss.weld.bootstrap.WeldStartup startContainer
INFO: WELD-000101: Transactional services not available. Injection of @Inject UserTransaction not available. Transactional observers will be invoked synchronously.
Feb 26, 2018 2:41:38 PM org.jboss.weld.event.ExtensionObserverMethodImpl checkRequiredTypeAnnotations
INFO: WELD-000411: Observer method [BackedAnnotatedMethod] public org.omnifaces.VetoAnnotatedTypeExtension.processAnnotatedType(@Observes ProcessAnnotatedType<T>) receives events for all annotated types. Consider restricting events using @WithAnnotations or a generic type with bounds.
Feb 26, 2018 2:41:38 PM org.jboss.weld.bootstrap.events.BeforeBeanDiscoveryImpl addAnnotatedType
WARN: WELD-000146: BeforeBeanDiscovery.addAnnotatedType(AnnotatedType<?>) used for class com.sun.faces.flow.FlowDiscoveryCDIHelper is deprecated from CDI 1.1!
Feb 26, 2018 2:41:39 PM org.jboss.weld.environment.tomcat.TomcatContainer initialize
INFO: WELD-ENV-001100: Tomcat 7+ detected, CDI injection will be available in Servlets, Filters and Listeners.
Feb 26, 2018 2:41:40 PM org.apache.catalina.core.ContainerBase startInternal
SCHWERWIEGEND: A child container failed during start
...
Caused by: org.jboss.weld.exceptions.DeploymentException: WELD-001408: Unsatisfied dependencies for type FooBean with qualifiers @Default
  at injection point [BackedAnnotatedField] @Inject private filter.FooFilter.fooBean
  at filter.FooFilter.fooBean(FooFilter.java:0)
WELD-001475: The following beans match by type, but none have matching qualifiers:
  - Managed Bean [class beans.fooBean] with qualifiers [@FacesConfig @Any @Named]
...

怎么了?

1 个答案:

答案 0 :(得分:1)

由于@FacesConfig限定符(这是stracktrace告诉你的),CDI / Weld找不到匹配的bean。将@Default限定符添加到FooBean。 @Default限定符是bean在没有明确指定限定符的情况下具有的限定符。

或者,您可以将@Any限定符添加到注入点。顾名思义,任何bean默认都有@Any限定符。