O filtro resolve o problema de caracteres ilegíveis, bloqueia palavras confidenciais e controla os direitos de acesso à página.

O filtro resolve o problema truncado

Interface de referência

public class filter implements Filter {
    
    
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
    
    
        servletRequest.setCharacterEncoding("UTF-8");
        servletResponse.setCharacterEncoding("UTF-8");
        servletResponse.setContentType("text/html; Charset =utf-8");
        filterChain.doFilter(servletRequest,servletResponse);
    }
}

A interface aqui não precisa ser totalmente implementada, apenas um doFilter precisa ser implementado. Porque há modificação padrão na interface

public interface Filter {
    
    
    default void init(javax.servlet.FilterConfig filterConfig) throws javax.servlet.ServletException {
    
     /* compiled code */ }

    void doFilter(javax.servlet.ServletRequest servletRequest, javax.servlet.ServletResponse servletResponse, javax.servlet.FilterChain filterChain) throws java.io.IOException, javax.servlet.ServletException;

    default void destroy() {
    
     /* compiled code */ }
}

Configurar em xml

<filter>
      <filter-name>character</filter-name>
      <filter-class>com.yim.Servlet.filter</filter-class>
   </filter>
   <filter-mapping>
      <filter-name>character</filter-name>
      <url-pattern>/test2</url-pattern>
   </filter-mapping>

Aqui está a conclusão do console e a saída para a página, não há problema truncado e não há necessidade de modificar o problema truncado para cada classe.

Nota: O escritor deturpou o problema

FileReader lê caracteres chineses truncados, preste atenção em UTF-8

        InputStream inputStream= req.getInputStream();
        Reader reader=new InputStreamReader(inputStream, "UTF-8");
        BufferedReader bufferedReader=new BufferedReader(reader);

Bloquear palavras sensíveis

@WebFilter("/test")
public class WordFilter implements Filter {
    
    
 @Override
 public void doFilter(ServletRequest servletRequest, ServletResponse
servletResponse, FilterChain filterChain) throws IOException, ServletException
{
    
    
 servletRequest.setCharacterEncoding("UTF-8");
 //将"敏感词"替换成"***"
 String name = servletRequest.getParameter("name");
 name = name.replaceAll("敏感词","***");
 servletRequest.setAttribute("name",name);
 filterChain.doFilter(servletRequest,servletResponse);
 }
}

Controle o acesso à página.

Se o usuário abrir diretamente o link de download sem fazer login, ele não irá pular para a página de download, mas sim para a página de login.
Use principalmente filtros de sessão e webfilter

@WebFilter("/download.jsp")
public class DownloadFilter implements Filter {
    
    
 @Override
 public void doFilter(ServletRequest servletRequest, ServletResponse
servletResponse, FilterChain filterChain) throws IOException, ServletException
{
    
    
 HttpServletRequest request = (HttpServletRequest) servletRequest;
 HttpServletResponse response = (HttpServletResponse) servletResponse;
 HttpSession session = request.getSession();
 String name = (String) session.getAttribute("name");
 if(name == null){
    
    
 //不是登录状态
 response.sendRedirect("/login.jsp");
 }else{
    
    
 filterChain.doFilter(servletRequest,servletResponse);
 }
 }
}

Acho que você gosta

Origin blog.csdn.net/yimzuenmuanggg/article/details/113329309
Recomendado
Clasificación