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:
- Výstupem je Test Param z parametru init
- A načtení IP adresy, data a času.