Відображення фільтрів у Web.xml

Що таке фільтри JSP?

  • Фільтри в web.xml використовуються для фільтрації функцій Java веб-додаток.
  • Вони перехоплюють запити від клієнта перед спробою отримати доступ до ресурсу
  • Вони маніпулюють відповідями від сервера та надсилають клієнту.

Типи фільтрів у JSP

  • Фільтри автентифікації
  • Фільтри стиснення даних
  • Фільтри шифрування
  • Ланцюгові фільтри MIME
  • Фільтри журналювання
  • Фільтри токенізації

Фільтри визначені в web.xml, і вони є картою сервлету або JSP. Коли JSP-контейнер запускається з веб-додатком, він створює екземпляр кожного фільтра в web.xml, який було оголошено в дескрипторі розгортання.

Методи фільтрації JSP

Нижче наведено методи фільтрації.

Public void doFilter(ServletRequest, ServletResponse, FilterChain)

Це викликається кожного разу, коли запит/відповідь передається від кожного клієнта, коли його запитують із ресурсу.

Публічна недійсна ініціалізація (FilterConfig)

Це означає, що фільтр у JSP введено в експлуатацію

Public void destroy()

Це означає, що фільтр вилучено з експлуатації.

Приклад

У цьому прикладі ми створили фільтр і зіставили його Java фільтр 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>

Пояснення коду

Gurufilter.java

Рядок коду 17-32: Тут ми використовуємо метод «doFilter», де ми отримуємо об’єкт запиту (у нашому прикладі об’єкт запиту — це req(HttpServletRequest object)) і отримуємо віддалену адресу клієнта та друкуємо на консолі, а також друкуємо дату й час на консоль.

Рядок коду 33-37: Тут ми використовуємо метод init, де ми беремо параметр init і друкуємо параметр init у консолі.

Web.xml

Рядок коду 10-11: Відображення фільтра в web.xml для GuruFilter з назвою класу GuruFilter.java, де ми маємо назву фільтра як GuruFilter і клас фільтра, який є шляхом до каталогу класу GuruFilter

Рядок коду 13-15: Відображення параметра init під назвою guru-param і отримання його значення, яке розміщується під тегом фільтра, щоб цей параметр init було визначено для gurufilter

вихід:

Коли ви виконуєте наведений вище код, ви отримуєте такий результат:

Методи фільтрації JSP

  • Результат тестування параметра init
  • І отримання IP-адреси, дати та часу.