Mapowanie filtrów w pliku Web.xml

Czym są filtry JSP?

  • Filtry w pliku web.xml służą do filtrowania funkcjonalności pliku Java Aplikacja internetowa.
  • Przechwytują żądania od klienta, zanim ten spróbuje uzyskać dostęp do zasobu
  • Manipulują odpowiedziami z serwera i wysyłanymi do klienta.

Rodzaje filtrów w JSP

  • Filtry uwierzytelniające
  • Filtry kompresji danych
  • Filtry szyfrujące
  • Filtry łańcuchowe MIME
  • Filtry rejestrowania
  • Filtry tokenizujące

Filtry są zdefiniowane w pliku web.xml i stanowią mapę do serwletu lub JSP. Kiedy kontener JSP uruchamia się z aplikacją internetową, tworzy instancję każdego filtra w pliku web.xml, który został zadeklarowany w deskryptorze wdrażania.

Metody filtrowania JSP

Poniżej przedstawiono metody filtrowania:

Publiczna void doFilter(ServletRequest, ServletResponse, FilterChain)

Jest to wywoływane za każdym razem, gdy żądanie/odpowiedź jest przekazywane od każdego klienta, gdy jest ono wymagane z zasobu.

Publiczna inicjalizacja pustki (FilterConfig)

Oznacza to, że filtr w JSP został oddany do użytku

Publiczne zniszczenie próżni()

Oznacza to, że filtr został wycofany z eksploatacji.

Przykład

W tym przykładzie utworzyliśmy filtr i zmapowaliśmy go Java filtr web.xml

Gurufilter.java

package demotest;

import java.io.IOException;
import java.util.Date;

import javax.servlet.Filter; 
import javax.servlet.FilterChain; 
import javax.servlet.FilterConfig; 
import javax.servlet.ServletException; 
import javax.servlet.ServletRequest; 
import javax.servlet.ServletResponse; 
import Javax.servlet.http.HttpServletRequest;


public class GuruFilter implements Filter {
	
	public void doFilter(ServletRequest request, ServletResponse response, Filterchain chain) throws IOException, ServletException {
		// TODO Auto-generated method stub 
		HttpServletRequest req = (HttpServletRequest) request;
		
		
		String ipAddress = req.getRemoteAddr(); 
		System.out.println("IP Address "+ipAddress + ", Time is" 
							+ new Date().toString());
		
		// pass the request along the filter chain 
		chain.doFilter(request, response);
	}
	
	/**
	* @see Filter#init(FilterConfig)
	*/ 
	public void init(FilterConfig fConfig) throws ServletException {
	String guruparam = fConfig.getInitParameter("guru-param");
	
	//Print the init parameter 
	System.out.println("Test Param: " + guruparam);
	}
}

Web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_ID" version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
	<display-name>
	test</display-name>
	<filter>
		<description>
		</description>
		<display-name>
		GuruFilter</display-name>
		<filter-name>GuruFilter</filter-name>
		<filter-class>demotest.GuruFilter</filter-class>
		<init-param>
		<param-name>guru-param</param-name>
		<param-value>This is guru paramter</param-value>
	</init-param>
	</filter>
	<filter-mapping>
	   <filter-name>GuruFilter</filter-name>
	   <url-pattern>/GuruFilter</url-pattern>
	</filter-mapping>

Wyjaśnienie kodu

Gurufilter.java

Linia kodu 17-32: Tutaj używamy metody „doFilter”, w której pobieramy obiekt żądania (w naszym przykładzie obiektem żądania jest req(obiekt HttpServletRequest)) i pobieramy zdalny adres klienta, a następnie drukujemy go na konsoli, a także drukujemy datę i godzinę na konsoli.

Linia kodu 33-37: Tutaj używamy metody init, w której pobieramy parametr init i drukujemy parametr init w konsoli.

Web.xml

Linia kodu 10-11: Mapowanie filtrów w web.xml dla GuruFilter z nazwą klasy GuruFilter.java, gdzie mamy nazwę filtra jako GuruFilter i klasę filtra, która jest ścieżką katalogu klasy GuruFilter

Linia kodu 13-15: Mapowanie parametru init o nazwie guru-param i pobieranie jego wartości, która jest umieszczona pod znacznikiem filtra, dzięki czemu ten parametr init został zdefiniowany dla gurufilter

Wyjście:

Po wykonaniu powyższego kodu otrzymasz następujący wynik:

Metody filtrowania JSP

  • Dane wyjściowe to Test Param z parametru init
  • I pobranie adresu IP, daty i godziny.