Filter Mapping i Web.xml
Hvad er JSP-filtre?
- Filtre i web.xml bruges til at filtrere funktionaliteten af Java webapplikation.
- De opsnapper anmodningerne fra klienten, før de forsøger at få adgang til ressourcen
- De manipulerer svarene fra serveren og sendes til klienten.
Filtretyper i JSP
- Godkendelsesfiltre
- Datakomprimeringsfiltre
- Krypteringsfiltre
- MIME-kædefiltre
- Logningsfiltre
- Tokeniserende filtre
Filtre er defineret i web.xml, og de er et kort til servlet eller JSP. Når JSP-containeren starter med webapplikationen, opretter den forekomsten af hvert filter i web.xml, der er blevet erklæret i implementeringsbeskrivelsen.
JSP-filtermetoder
Følgende er filtermetoderne:
Offentlig void doFilter(ServletRequest, ServletResponse, FilterChain)
Dette kaldes hver gang, når en anmodning/svar sendes fra hver klient, når det anmodes fra en ressource.
Offentlig void init(FilterConfig)
Dette er for at indikere, at filter i JSP er taget i brug
Offentlig ugyldighed ødelægge()
Dette for at angive, at filteret er taget ud af drift.
Eksempel
I dette eksempel har vi lavet filter og kortlagt ind 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>
Forklaring af koden
Gurufilter.java
Kodelinje 17-32: Her bruger vi "doFilter"-metoden, hvor vi får request-objekt (i vores eksempel er request-objektet req(HttpServletRequest-objekt)) og henter klientens fjernadresse og udskriver på konsollen og udskriver også dato og klokkeslæt på konsol.
Kodelinje 33-37: Her bruger vi init-metoden, hvor vi tager init-parameteren og udskriver init-parameteren i konsollen.
Web.xml
Kodelinje 10-11: Filtermapping i web.xml for GuruFilter med klassenavnet GuruFilter.java hvor vi har filternavn som GuruFilter og filterklasse som er biblioteksstien til GuruFilter-klassen
Kodelinje 13-15: Kortlægning af init-parameteren ved navn guru-param og få værdien af den, som er placeret under filter-tag, så denne init-param er blevet defineret for gurufilter
Output:
Når du udfører ovenstående kode, får du følgende output:
- Outputtet er Test Param fra init-parameteren
- Og henter IP-adresse, dato og klokkeslæt for det.