Mapování filtrů v souboru Web.xml

Co jsou JSP filtry?

  • Filtry ve web.xml se používají k filtrování Java webová aplikace.
  • Zachycují požadavky od klienta dříve, než se pokusí získat přístup ke zdroji
  • Manipulují s odpověďmi ze serveru a odeslanými klientovi.

Typy filtrů v JSP

  • Autentizační filtry
  • Filtry pro kompresi dat
  • Šifrovací filtry
  • MIME řetězové filtry
  • Filtry protokolování
  • Tokenizační filtry

Filtry jsou definovány v web.xml a jsou mapou na servlet resp JSP. Když se kontejner JSP spustí s webovou aplikací, vytvoří instanci každého filtru v souboru web.xml, který byl deklarován v deskriptoru nasazení.

Metody filtrování JSP

Níže jsou uvedeny metody filtrování:

Public void doFilter(ServletRequest, ServletResponse, FilterChain)

To je voláno pokaždé, když je požadavek/odpověď předán od každého klienta, když je požadován ze zdroje.

Public void init (FilterConfig)

To znamená, že filtr v JSP je uveden do provozu

Veřejné void zničit()

To znamená, že filtr byl vyřazen z provozu.

Příklad

V tomto příkladu jsme vytvořili filtr a namapovali jej 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>

Vysvětlení kódu

Gurufilter.java

Řádek kódu 17-32: Zde používáme metodu „doFilter“, kde získáváme objekt požadavku (v našem příkladu je objekt požadavku req(objekt HttpServletRequest)) a získáváme vzdálenou adresu klienta a tiskneme na konzole a také tiskneme datum a čas na utěšit.

Řádek kódu 33-37: Zde používáme metodu init, kdy bereme parametr init a vypisujeme parametr init v konzole.

Web.xml

Řádek 10–11 kódu: Mapování filtru ve web.xml pro GuruFilter s názvem třídy GuruFilter.java, kde máme název filtru jako GuruFilter a třídu filtru, což je cesta k adresáři třídy GuruFilter

Řádek 13–15 kódu: Mapování init parametru s názvem guru-param a získání jeho hodnoty, která je umístěna pod tagem filtru, takže tento init-param byl definován pro gurufilter

Výstup:

Když spustíte výše uvedený kód, získáte následující výstup:

Metody filtrování JSP

  • Výstupem je Test Param z parametru init
  • A načtení IP adresy, data a času.