在我大天朝,并不是言论自由的 。。。要过滤 。。。。
其实原理很简单,就是对指定的字符提取然后替换
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
public class MyHttpRequest extends HttpServletRequestWrapper {
public MyHttpRequest(HttpServletRequest request) {
super(request);
}
@Override
public String getParameter(String name) {
String string = super.getParameter(name);
if (string != null && string.contains("fuck")) {
string = string.replaceAll("fuck", "****");
}
return super.getParameter(name);
}
}
自定义的MyHttpRequest继承HttpServletRequestWrapper这个类,然后重写getParameter方法,为啥要重写这个方法了 ? 这里就不解释 了。 。 然后操作搞一搞过滤器
import java.io.IOException;
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.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
/**
* Servlet Filter implementation class FuckFilter
*/
@WebFilter("/FuckFilter")
public class FuckFilter implements Filter {
/**
* Default constructor.
*/
public FuckFilter() {
// TODO Auto-generated constructor stub
}
/**
* @see Filter#destroy()
*/
public void destroy() {
// TODO Auto-generated method stub
}
/**
* @see Filter#doFilter(ServletRequest, ServletResponse, FilterChain)
*/
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
MyHttpRequest myHttpRequest = new MyHttpRequest((HttpServletRequest) request);
chain.doFilter(myHttpRequest, response);
}
/**
* @see Filter#init(FilterConfig)
*/
public void init(FilterConfig fConfig) throws ServletException {
// TODO Auto-generated method stub
}
}
不解释了,超级简单。。。。。