Mappatura dei filtri in Web.xml
Cosa sono i filtri JSP?
- I filtri in web.xml vengono utilizzati per filtrare la funzionalità di Java applicazione web.
- Intercettano le richieste del client prima di tentare di accedere alla risorsa
- Manipolano le risposte dal server e le inviano al client.
Tipi di filtri in JSP
- Filtri di autenticazione
- Filtri di compressione dati
- Filtri di crittografia
- Filtri della catena MIME
- Filtri di registrazione
- Filtri di tokenizzazione
I filtri sono definiti in web.xml e sono una mappa per servlet o JSP. Quando il contenitore JSP viene avviato con l'applicazione Web, crea l'istanza di ciascun filtro in web.xml dichiarato nel descrittore di distribuzione.
Metodi di filtro JSP
Di seguito sono riportati i metodi di filtro:
Pubblico void doFilter(ServletRequest, ServletResponse, FilterChain)
Viene chiamato ogni volta che una richiesta/risposta viene passata da ogni client quando viene richiesta da una risorsa.
Init pubblico vuoto (FilterConfig)
Ciò indica che il filtro in JSP è stato messo in servizio
Distruggi il vuoto pubblico()
Questo per indicare che il filtro è stato messo fuori servizio.
Esempio
In questo esempio, abbiamo creato il filtro e mappato Java filtro 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>
Spiegazione del codice
Gurufilter.java
Riga di codice 17-32: Qui utilizziamo il metodo "doFilter" con cui otteniamo l'oggetto richiesta (nel nostro esempio l'oggetto richiesta è req(oggetto HttpServletRequest)) e otteniamo l'indirizzo remoto del client e lo stampiamo sulla console, oltre a stampare data e ora sulla console.
Riga di codice 33-37: Qui stiamo utilizzando il metodo init in cui prendiamo il parametro init e stampiamo il parametro init nella console.
Web.xml
Riga di codice 10-11: Mappatura del filtro in web.xml per GuruFilter con il nome della classe GuruFilter.java dove abbiamo il nome del filtro come GuruFilter e la classe del filtro che è il percorso della directory della classe GuruFilter
Riga di codice 13-15: Mappatura del parametro init denominato guru-param e ottenimento del suo valore che è posizionato sotto il tag filtro in modo che questo init-param sia stato definito per gurufilter
Produzione:
Quando esegui il codice sopra, ottieni il seguente output:
- L'output è Test Param dal parametro init
- E recuperarne l'indirizzo IP, la data e l'ora.