我已经创建了一个web应用程序,它使用Weld-2.2.0CDI实现,并运行在Tomcat-7上。我已经创建了一个拦截器来记录方法调用。但是,当我运行应用程序时,它会绕过拦截器并直接调用方法。
我的拦截器构造如下:
拦截器绑定:
@Inherited
@InterceptorBinding
@Retention(RUNTIME)
@Target({METHOD, TYPE})
public @interface LogMe{
}拦截器类别:
@LogMe
@Interceptor
public class LogInterceptorImpl
{
private static final Logger log = LogManager.getLogger(LogInterceptorImpl.class);
@AroundInvoke
public Object intercept(InvocationContext ctx) throws Exception
{
log.debug("LogInterceptor::intercept");
return ctx.proceed();
}
}拦截目标:
@LogMe
public class DefaultAppController extends AbstractBaseController
{
private static final long serialVersionUID = 1L;
public DefaultAppController()
{
}
@Override @LogMe
public void processRequest(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException
{
resp.getWriter().write("Hello, Guest !");
}
}最后,我创建了如下beans.xml文件:
<beans xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/beans_1_0.xsd">
<interceptors>
<class>x.web.interceptors.LogInterceptorImpl</class>
</interceptors>
</beans>我还在context.xml文件和web.xml文件中创建了焊缝资源引用(如焊接文档所述)。
<Resource name="BeanManager"
auth="Container"
type="javax.enterprise.inject.spi.BeanManager"
factory="org.jboss.weld.resources.ManagerObjectFactory" />和
<resource-env-ref>
<resource-env-ref-name>BeanManager</resource-env-ref-name>
<resource-env-ref-type>javax.enterprise.inject.spi.BeanManager</resource-env-ref-type>
</resource-env-ref>我尝试了大量的视光器,包括使用焊猫支持jar进行集成,但它们似乎都不起作用。
有人能帮我吗?
我是错过了还是做错了什么?
发布于 2014-12-03 11:02:30
我不认为拦截器在Java容器之外工作。我想独立焊接只能做DI,但不能做其他功能。还请参阅以下文章:Is it possible to use javax.interceptor in a Java SE environment?
https://stackoverflow.com/questions/27269482
复制相似问题