Відображення фільтрів у 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
вихід:
Коли ви виконуєте наведений вище код, ви отримуєте такий результат:
- Результат тестування параметра init
- І отримання IP-адреси, дати та часу.