在编写用户注册模块时,我们常常需要过滤一部分敏感词汇作为用户名。可以通过filter来实现这一功能,一下为具体实现的方法:
1、编写filter过滤关键字
public class NameCheck extends HttpServlet implements Filter{
private String[] keywords;
@Override
public void doFilter(ServletRequest arg0, ServletResponse arg1,
FilterChain arg2) throws IOException, ServletException {
// TODO Auto-generated method stub
//接受用户名
String name=arg0.getParameter("userName");
//判断的时候如果变量为空,会报空指针异常
if(name!=null){
for(String key:keywords){
if(key.equals(name)){
arg0.setAttribute("err", "被过滤器拦截<font color='red'>"+name+"</font>是关键字");
arg0.getRequestDispatcher("/WEB-INF/name_err.jsp").forward(arg0, arg1);
return ;
}
}
}
arg2.doFilter(arg0, arg1);
}
@Override
public void init(FilterConfig arg0) throws ServletException {
// TODO Auto-generated method stub
keywords=arg0.getInitParameter("keywords").split(";");
}
}
接收到用户注册的用户名,并判断用户名是否为关键字,如果为关键字,则返回注册界面,重新注册。
2、在web.xml中配置filter,并设置关键字
<filter>
<filter-name>NameCheck</filter-name>
<filter-class>com.sevend.filter.NameCheck</filter-class>
<!-- 在这里配置属性,实现多个字符的过滤 -->
<init-param>
<param-name>keywords</param-name>
<param-value>拉登;管理员;领导人;</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>NameCheck</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
配置完成web.xml就可以实现敏感词汇的过滤,从代码中可以看出,敏感词汇被配置在web.xml文件的初始值中。