Mapowanie filtrów w pliku Web.xml
Czym są filtry JSP?
- Filtry w pliku web.xml służą do filtrowania funkcjonalności pliku Java Aplikacja internetowa.
- Przechwytują żądania od klienta, zanim ten spróbuje uzyskać dostęp do zasobu
- Manipulują odpowiedziami z serwera i wysyłanymi do klienta.
Rodzaje filtrów w JSP
- Filtry uwierzytelniające
- Filtry kompresji danych
- Filtry szyfrujące
- Filtry łańcuchowe MIME
- Filtry rejestrowania
- Filtry tokenizujące
Filtry są zdefiniowane w pliku web.xml i stanowią mapę do serwletu lub JSP. Kiedy kontener JSP uruchamia się z aplikacją internetową, tworzy instancję każdego filtra w pliku web.xml, który został zadeklarowany w deskryptorze wdrażania.
Metody filtrowania JSP
Poniżej przedstawiono metody filtrowania:
Publiczna void doFilter(ServletRequest, ServletResponse, FilterChain)
Jest to wywoływane za każdym razem, gdy żądanie/odpowiedź jest przekazywane od każdego klienta, gdy jest ono wymagane z zasobu.
Publiczna inicjalizacja pustki (FilterConfig)
Oznacza to, że filtr w JSP został oddany do użytku
Publiczne zniszczenie próżni()
Oznacza to, że filtr został wycofany z eksploatacji.
Przykład
W tym przykładzie utworzyliśmy filtr i zmapowaliśmy go Java filtr 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>
Wyjaśnienie kodu
Gurufilter.java
Linia kodu 17-32: Tutaj używamy metody „doFilter”, w której pobieramy obiekt żądania (w naszym przykładzie obiektem żądania jest req(obiekt HttpServletRequest)) i pobieramy zdalny adres klienta, a następnie drukujemy go na konsoli, a także drukujemy datę i godzinę na konsoli.
Linia kodu 33-37: Tutaj używamy metody init, w której pobieramy parametr init i drukujemy parametr init w konsoli.
Web.xml
Linia kodu 10-11: Mapowanie filtrów w web.xml dla GuruFilter z nazwą klasy GuruFilter.java, gdzie mamy nazwę filtra jako GuruFilter i klasę filtra, która jest ścieżką katalogu klasy GuruFilter
Linia kodu 13-15: Mapowanie parametru init o nazwie guru-param i pobieranie jego wartości, która jest umieszczona pod znacznikiem filtra, dzięki czemu ten parametr init został zdefiniowany dla gurufilter
Wyjście:
Po wykonaniu powyższego kodu otrzymasz następujący wynik:
- Dane wyjściowe to Test Param z parametru init
- I pobranie adresu IP, daty i godziny.