用过滤器对jsp页面中的敏感字段进行过滤
来源:互联网 发布:知乎怎么改个性域名 编辑:程序博客网 时间:2024/05/05 18:39
WordWriter.java
package myservlets;
package myservlets;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.PrintWriter;
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.HttpServletResponse;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletResponse;
public class WordWriter implements Filter {
protected FilterConfig filterConfig;
public void destroy() {
this.filterConfig=null;
}
public void destroy() {
this.filterConfig=null;
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException,
ServletException {
request.setCharacterEncoding("UTF-8");
response.setContentType("text/html;charset=UTF-8");
HttpServletResponse res=(HttpServletResponse) response;
PrintWriter out=response.getWriter();
CharResponseWrapper wrapper=new CharResponseWrapper(res);
chain.doFilter(request, wrapper);
String resStr=wrapper.toString();
request.setCharacterEncoding("UTF-8");
response.setContentType("text/html;charset=UTF-8");
HttpServletResponse res=(HttpServletResponse) response;
PrintWriter out=response.getWriter();
CharResponseWrapper wrapper=new CharResponseWrapper(res);
chain.doFilter(request, wrapper);
String resStr=wrapper.toString();
//敏感字符集
List<String> illegal_wordList = new ArrayList<String>();
illegal_wordList.add("妈的");
illegal_wordList.add("垃圾");
for (Iterator iter = illegal_wordList.iterator(); iter.hasNext();) {
String element = (String) iter.next();
if (resStr.indexOf(element) > 0) {
resStr = resStr.replaceAll(element, "**");
}
} out.println(resStr);
}
List<String> illegal_wordList = new ArrayList<String>();
illegal_wordList.add("妈的");
illegal_wordList.add("垃圾");
for (Iterator iter = illegal_wordList.iterator(); iter.hasNext();) {
String element = (String) iter.next();
if (resStr.indexOf(element) > 0) {
resStr = resStr.replaceAll(element, "**");
}
} out.println(resStr);
}
public void init(FilterConfig config) throws ServletException {
this.filterConfig=config;
}
this.filterConfig=config;
}
public void setFilterConfig(final FilterConfig filterConfig) {
this.filterConfig = filterConfig;
}
this.filterConfig = filterConfig;
}
}
CharResponseWrapper.java
package myservlets;
package myservlets;
import java.io.CharArrayWriter;
import java.io.PrintWriter;
import java.io.PrintWriter;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpServletResponseWrapper;
import javax.servlet.http.HttpServletResponseWrapper;
public class CharResponseWrapper extends HttpServletResponseWrapper {
private CharArrayWriter output;
private CharArrayWriter output;
public String toString() {
return output.toString();
}
return output.toString();
}
public CharResponseWrapper(HttpServletResponse response) {
super(response);
output = new CharArrayWriter();
}
super(response);
output = new CharArrayWriter();
}
public PrintWriter getWriter() {
return new PrintWriter(output);
}
}
return new PrintWriter(output);
}
}
MyJsp.jsp
<%@ page language="java" pageEncoding="gb2312"%>
<%@ page language="java" pageEncoding="gb2312"%>
<%@ taglib uri="http://struts.apache.org/tags-bean" prefix="bean" %>
<%@ taglib uri="http://struts.apache.org/tags-html" prefix="html" %>
<%@ taglib uri="http://struts.apache.org/tags-logic" prefix="logic" %>
<%@ taglib uri="http://struts.apache.org/tags-tiles" prefix="tiles" %>
<%@ taglib uri="http://struts.apache.org/tags-html" prefix="html" %>
<%@ taglib uri="http://struts.apache.org/tags-logic" prefix="logic" %>
<%@ taglib uri="http://struts.apache.org/tags-tiles" prefix="tiles" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html:html lang="true">
<head>
<html:base />
<title>MyJsp.jsp</title>
</head>
<body>
This a struts page. <br>
真她妈的!垃圾
</body>
</html:html>
<html:html lang="true">
<head>
<html:base />
<title>MyJsp.jsp</title>
</head>
<body>
This a struts page. <br>
真她妈的!垃圾
</body>
</html:html>
web.xml
<filter>
<filter-name>Word Filter</filter-name>
<filter-class>myservlets.WordWriter</filter-class>
</filter>
<filter-mapping>
<filter-name>Word Filter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
效果:
This a struts page.
真她**!**
真她**!**
- 用过滤器对jsp页面中的敏感字段进行过滤
- java 过滤器对敏感词过滤
- 过滤器-过滤敏感词汇
- 实现Struts2中对未登录的jsp页面进行拦截功能(采用的是Struts2中过滤器进行过滤拦截)
- 用过滤器对页面数据进行压缩
- Java Web对前台传过来参数中的敏感字符进行过滤替换
- 自定义Filter过滤器,过滤所有jsp页面
- Jsp敏感词过滤
- 写一个过滤器,不想对某些文件进行过滤,在web.xml中的配置
- 用java过滤文章中的敏感词
- 过滤器实现对未登录用户访问JSP页面,进行控制。
- 过滤器(Filter)应用之------设置页面缓存、用户的自动登录和敏感词过滤
- jsp页面对重复数据过滤
- 用Servlet、JSP实现帐号注册页面,用过滤器过滤对象防止中文乱码
- filter对页面内容敏感词进行替换处理
- filter对页面内容敏感词进行替换处理
- 用jsp对oracle的clob字段进行操作
- 用jsp对oracle的clob字段进行操作
- 嵌入式系统设计和Windows CE - ShowMan的专栏 - CSDNBlog
- gridview 双击单击事件
- 第一篇
- 关于IT服务:服务是需要不断改进和培训之如何去做解答?(故事三)
- 一个同行对JAVA的理解
- 用过滤器对jsp页面中的敏感字段进行过滤
- 降低耦合
- 心路历程
- [同事原创] 开源搜索引擎Hyper Estraier性能小测&缺点总结
- 生男女比例题解
- 初次接触KDevelop,C++ compiler cannot create executables问题的解决办法
- Sed简明速查手册
- [xml]jocky build
- 收集的JS代码,学习js的入门经典