Filtriraj kartuping 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

Code Linija 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.

Code Linija 33-37: Ovdje koristimo init metodu gdje uzimamo init parametar i ispisujemo init parametar u konzoli.

Web.xml

Code Redak 10-11: Filtriraj kartuping u web.xml za GuruFiltriraj prema nazivu klase GuruFilter.java gdje imamo naziv filtera kao GuruFilter i klasa filtera koja je put direktorija GuruKlasa filtera

Code Redak 13-15: Kartaping init parametar 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:

Metode JSP filtera

  • Izlaz je Test Param iz init parametra
  • I dohvaฤ‡anje IP adrese, datuma i vremena.

Saลพmite ovu objavu uz: