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);
}
}
}