Я пытаюсь использовать ContainerRequestFilter
для обеспечения некоторой аутентификации на основе приложения на основе Tomcat. Я следовал this document. Проблема: фильтр никогда не срабатываетJersey ContainerRequestFilter не активирован
Класс фильтра:
@Provider
public class AuthFilter implements ContainerRequestFilter {
@Override
public void filter(ContainerRequestContext requestContext)
throws IOException {
// MY AUTHENTICATION CODE GOES HERE
}
Файл web.xml:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
id="debate-rest"
version="3.0">
<display-name>rest</display-name>
<servlet>
<servlet-name>Jersey REST Service</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>com.sun.jersey.spi.container.ContainerRequestFilters</param-name>
<param-value>com.hck.debate.rest.security.AuthFilter</param-value>
</init-param>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>com.hck.debate.rest.controller</param-value>
</init-param>
<init-param>
<param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name>
<param-value>true</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Jersey REST Service</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
Ваш выше код работает, как это с TomCat, может быть, по-другому с Glas рыбы –
поведение по умолчанию для сканирования рекурсивно, так что вы можете просто использовать единый базовый пакет ' com.hck.debate.rest' –
Также обратите внимание, что 'com.sun.jersey.spi.container.ContainerRequestFilters' и' com.sun.jersey.api.json.POJOMappingFeature' бесполезны. Это свойства Джерси 1.x. Они не влияют на Джерси 2.x –