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:

JSP-filtermetoder

  • Outputtet er Test Param fra init-parameteren
  • Og henter IP-adresse, dato og klokkeslæt for det.