Mapeamento de filtros em Web.xml
O que são filtros JSP?
- Os filtros em web.xml são usados para filtrar a funcionalidade do Java aplicação web.
- Eles interceptam as solicitações do cliente antes de tentarem acessar o recurso
- Eles manipulam as respostas do servidor e as enviam ao cliente.
Tipos de filtros em JSP
- Filtros de autenticação
- Filtros de compactação de dados
- Filtros de criptografia
- Filtros de cadeia MIME
- Filtros de registro
- Filtros de tokenização
Os filtros são definidos em web.xml e são um mapa para servlet ou JSP. Quando o contêiner JSP inicia com o aplicativo da web, ele cria a instância de cada filtro em web.xml que foi declarado no descritor de implantação.
Métodos de filtro JSP
A seguir estão os métodos de filtro:
Público void doFilter(ServletRequest, ServletResponse, FilterChain)
Isso é chamado sempre que uma solicitação/resposta é passada de cada cliente quando é solicitada de um recurso.
Inicialização nula pública (FilterConfig)
Isto é para indicar que o filtro em JSP foi colocado em serviço
Destruição de vazio público()
Isso indica que o filtro foi retirado de serviço.
Exemplo
Neste exemplo, criamos filtro e mapeamos em Java filtro 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>
Explicação do código
Gurufilter.java
Linha de código 17-32:Aqui estamos usando o método “doFilter” onde obtemos o objeto de solicitação (em nosso exemplo, o objeto de solicitação é req(objeto HttpServletRequest)) e obtemos o endereço remoto do cliente e imprimimos no console, além de imprimir a data e a hora no console.
Linha de código 33-37: Aqui estamos usando o método init, onde pegamos o parâmetro init e imprimimos o parâmetro init no console.
Web.xml
Linha de código 10-11: Mapeamento de filtro em web.xml para GuruFilter com o nome de classe GuruFilter.java onde temos o nome do filtro como GuruFilter e a classe do filtro que é o caminho do diretório da classe GuruFilter
Linha de código 13-15: Mapeando o parâmetro init chamado guru-param e obtendo o valor dele que é colocado sob a tag filter para que este init-param tenha sido definido para gurufilter
Saída:
Ao executar o código acima, você obtém a seguinte saída:
- A saída é Test Param do parâmetro init
- E buscando endereço IP, data e hora.