Filter Mapiranje u Web.xml
Što su JSP filteri?
- Filtri u web.xml koriste se za filtriranje funkcionalnosti Java web aplikacija.
- Oni presreću zahtjeve klijenata prije nego što pokušaju pristupiti resursu
- Oni manipuliraju odgovorima s poslužitelja i poslanim klijentu.
Vrste filtera u JSP-u
- Filtri za provjeru autentičnosti
- Filtri za kompresiju podataka
- Filtri šifriranja
- MIME lančani filtri
- Filtri za bilježenje
- Filtri za tokenizaciju
Filteri su definirani u web.xml, a mapiraju se na servlet ili JSP. Kada se JSP spremnik pokrene s web-aplikacijom, on stvara instancu svakog filtra u web.xml koji je deklariran u deskriptoru implementacije.
Metode JSP filtera
Slijede metode filtriranja:
Javni void doFilter(ServletRequest, ServletResponse, FilterChain)
Ovo se poziva svaki put kada se zahtjev/odgovor proslijedi od svakog klijenta kada se to zatraži od resursa.
Javna void init (FilterConfig)
Ovo označava da je filtar u JSP-u stavljen u funkciju
Public void destroy()
Ovo označava da je filter povučen iz upotrebe.
Primjer
U ovom smo primjeru stvorili filtar i mapirali ga Java web.xml filter
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>
Objašnjenje koda
Gurufilter.java
Redak koda 17-32: Ovdje koristimo metodu “doFilter” gdje dobivamo objekt zahtjeva (u našem primjeru objekt zahtjeva je req(HttpServletRequest object)) i dobivamo udaljenu adresu klijenta te ispisujemo na konzoli i također ispisujemo datum i vrijeme na konzola.
Redak koda 33-37: Ovdje koristimo init metodu gdje uzimamo init parametar i ispisujemo init parametar u konzoli.
Web.xml
Redak koda 10-11: Mapiranje filtera u web.xml za GuruFilter s nazivom klase GuruFilter.java gdje imamo naziv filtera kao GuruFilter i klasu filtera koja je put direktorija klase GuruFilter
Redak koda 13-15: Mapiranje init parametra pod nazivom guru-param i dobivanje njegove vrijednosti koja se nalazi pod oznakom filtera tako da je ovaj init-param definiran za gurufilter
Izlaz:
Kada izvršite gornji kod, dobit ćete sljedeći izlaz:
- Izlaz je Test Param iz init parametra
- I dohvaćanje IP adrese, datuma i vremena.

