2016-02-05 44 views
1

我想用一个ContainerRequestFilter来实施基于灰熊的泽西岛应用程序的一些身份验证。泽西岛没有触发ContainerRequestFilter

我通过扩展PackagesResourceConfig创建自己的资源配置:

public class MainResourceConfig extends PackagesResourceConfig { 

    public MainResourceConfig() { 
     super("za.co.quinn.ws"); 
     Map<String, Object> properties = getProperties(); 
     properties.put(
       "com.sun.jersey.spi.container.ContainerRequestFilter", 
       "com.sun.jersey.api.container.filter.LoggingFilter;" + MainRequestFilter.class.getName() 
     ); 
     properties.put(
       "com.sun.jersey.spi.container.ContainerResponseFilters", 
       "com.sun.jersey.api.container.filter.LoggingFilter;" + MainResponseFilter.class.getName() 
     ); 
    } 
} 

请求筛选器是用于身份验证:

@Inject 
Authorization authorization; 

@Override 
public ContainerRequest filter(ContainerRequest request) { 

    if (!request.getRequestUri().getPath().endsWith(".wadl")) 
     authorization.authorize(request); 

    return request; 
} 

的响应滤波器是头:

@Override 
public ContainerResponse filter(ContainerRequest request, ContainerResponse response) { 

    response.getHttpHeaders().add("Access-Control-Allow-Origin", "*"); 
    response.getHttpHeaders().add("Access-Control-Allow-Methods", "GET, HEAD, POST, DELETE, PUT"); 
    response.getHttpHeaders().add("Access-Control-Allow-Headers", "Authorization, Content-Type"); 

    return response; 
} 

的MainResponseFilter确实被触发,但不是ContainerRequestFilter。

回答

1

“MainResponseFilter确实被触发,但不是ContainerRequestFilter。”

看看你的财产,主要是它的发送,并加以比较

...container.ContainerRequestFilter" 

...container.ContainerResponseFilters" 

您缺少请求过滤器的s。为了避免这样的拼写错误,你可以使用常量

你也可以做

getContainerRequestFilters().add(new YourRequestFilter()); 
getContainerResponseFilters().add(new YourResponseFilter());