私は組み込みの Jetty を使用しており、サーブレット フィルターを追加して、各リクエストの前に認証を確認したいと考えています。この例に従ってみましたが、署名が変更されたようです。
<dependency>
<groupId>org.eclipse.jetty</groupId>
<artifactId>jetty-server</artifactId>
<version>9.0.4.v20130625</version>
</dependency>
私の Jetty スターターは次のようになります。
public class JettyStarter {
public static void main( final String[] args ) throws Exception {
Server server = new Server(8080);
final ServletHolder servletHolder = new ServletHolder(new CXFServlet());
final ServletContextHandler context = new ServletContextHandler();
context.setContextPath("/");
// context.addFilter(AuthenticationFilter.class, "/*", FilterMapping.REQUEST);
context.addServlet(servletHolder, "/platform/*");
context.addEventListener(new ContextLoaderListener());
context.setInitParameter("contextClass", AnnotationConfigWebApplicationContext.class.getName());
context.setInitParameter("contextConfigLocation", Config.class.getName());
server.setHandler(context);
server.start();
server.join();
}
}
行のコメントを外すと
// context.addFilter(AuthenticationFilter.class, "/*", FilterMapping.REQUEST);
署名が変更されていることがわかりました。では、少し戻って、組み込みの Jetty を使用して、リクエストの開始時に実行され、何らかの条件が満たされた場合にのみリクエストを続行できるようにするフィルターを追加するにはどうすればよいでしょうか?
AuthenticationFilter クラスの冒頭は次のようになります。
import javax.servlet.*;
import java.io.IOException;
public class AuthenticationFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {}
@Override
public void doFilter(ServletRequest servletRequest,
ServletResponse servletResponse,
FilterChain filterChain) throws IOException, ServletException {}
@Override
public void destroy() {}
}