0

我在设置 Java EE 6 CDI 拦截器时遇到问题。我正在使用嵌入式 glassfish,我在 web 应用程序的 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>ServiceInterceptor</class>
    </interceptors>
</beans>

我正在尝试保护这个 bean:

@Named
//@Stateless
@RequestScoped
public class SecuredMethodJSFBean /*implements Serializable*/{
    @Inject
    protected SecuredMethodSample securedMethodSample;

    /*
    @CurrentUser
    @SessionScoped
    @Inject
    protected RuntimePrincipalAware principal;
    //protected JSFLoginBean jsfLoginBean;
    */

    public SecuredMethodJSFBean()
    {
        super();
        System.out.println("creating secured method jsf bean");
    }

    @Secured("adfadfafd")
    public void doSomething()
    {
        //System.out.println("\n\n\n\nprincipal:" + principal);
        //System.out.println("principal:" + jsfLoginBean.getPrincipal());

        //securedMethodSample.doSomething(jsfLoginBean.getPrincipal().getName());
        //return(jsfLoginBean.getPrincipal().getName());

        //securedMethodSample.doSomething(principal.getName());
        //return(principal.getName());
        //return("secured-method");

        securedMethodSample.doSomething("testing ...");
    }
}

我需要做什么才能让我的拦截器运行?

此外,我正在尝试使用拦截器来拦截 servlet 使用的 bean 上的方法调用。由于那些豆子是豆子,我应该能够拦截它们。但是,我无法这样做。我最初试图直接拦截 servlet 中的方法调用,但它们不是 CDI bean,所以这没有意义。

谢谢,

沃尔特

4

2 回答 2

1

“我已经在 web 应用程序的 beans.xml 中指定了拦截器”

@Secured 是否在另一个项目/jar 中定义?在这种情况下,您需要在该 beans.xml 中启用它。

于 2013-02-23T18:28:02.297 回答
0

为了更好地回答我的问题,我做了以下事情:

  1. 我制作了项目 ejb 而不是 jar(在 maven 内)。
  2. 我创建了一个 ejb-jar.xml 文件,指定/声明我的拦截器 (src/main/resources/META-INF)。
  3. 在使用此拦截器的项目中,我将类型指定为 ejb 以使其正确拾取。

沃尔特

于 2013-02-22T03:50:11.840 回答