8.0版本以上的tomcat为我们解决了get请求的乱码问题。我们需要自己处理post请求的乱码问题,因为我们的一个项目中可能有很多的请求。当然,我们可以在每一个Servlet中都对post的乱码进行处理。但是,Filter给我们提供了一个更加便捷的方式。我们自定义一个Filter类,拦截所有的请求,然后对这些请求进行post乱码处理即可。
//处理post 请求页面乱码
request.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=utf-8");
但是,Filter给我们提供了一个更加便捷的方式。我们自定义一个Filter类,拦截所有的请求,然后对这些请求进行post乱码处理即可。
EncodingFilter代码
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebFilter(filterName = "EncodingFilter",urlPatterns = "/*")
public class EncodingFilter implements Filter {
public void destroy() {
}
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
HttpServletRequest request = (HttpServletRequest) req;
request.setCharacterEncoding("UTF-8");
HttpServletResponse response = (HttpServletResponse) resp;
response.setContentType("text/html;charset=utf-8");
chain.doFilter(request, response);
}
public void init(FilterConfig config) throws ServletException {
}
}
下面是一个filter过滤非常字符的例子
【需求分析】
1.创建一个表单用于发表言论。
2.创建一个txt文件,其中存入非法字符。
3.创建一个Filter,拦截请求。在init方法中将txt文件中的非法字符读取到内存中。
4.获取请求中的参数,对请求的参数进行非法字符的校验。
5.如果言论中不含有非法字符,就放行。
6.如果言论中含有非法字符,就拦截,并且提示用户非法言论
form.jsp代码
<%--
Created by IntelliJ IDEA.
User: chensiyuan
Date: 2018/12/28
Time: 4:16 PM
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<form action="/wordsServlet" method="post">
用户名:<input type="text" name="userName"><br>
评论:<textarea name="desc"></textarea><br>
<input type="submit" value="提交">
</form>
</body>
</html>
WordsFilter代码
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import java.io.*;
@WebFilter(filterName = "WordsFilter",urlPatterns = "/wordsServlet")
public class WordsFilter implements Filter {
StringBuffer sb = new StringBuffer();
public void destroy() {
}
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
//获取请求的数据
HttpServletRequest request = (HttpServletRequest) req;
String desc =request.getParameter("desc");
if (sb.toString().contains(desc)){
resp.getWriter().println("对不起,您提交的内容有敏感词汇,请用文明用语");
return;
}
chain.doFilter(req, resp);
}
public void init(FilterConfig config) throws ServletException {
//在init方法中加载出敏感词库
String realPath = config.getServletContext().getRealPath("badwords.txt");
String line =null;
//读取词库
try {
InputStreamReader isr = new InputStreamReader(new FileInputStream(realPath),"UTF-8");
BufferedReader br = new BufferedReader(isr);
while((line=br.readLine())!=null ){
sb.append(line);
}
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
System.out.println(sb.toString());
}
}