JAvaフィルタ(filter)敏感語彙フィルタリングを実現

2481 ワード

分析:1.requestオブジェクトを強化します.パラメータ取得に関するメソッドを強化します.フィルタリングされた敏感な語彙をinitでロードするtxtテキストに配置します.txtフィルタリングされた敏感語彙に中国語がある場合は、符号化フォーマットをGBK.package cn.easyArch.web.filterに変換します.
import javax.servlet.*; import javax.servlet.annotation.WebFilter; import java.io.BufferedReader; import java.io.FileNotFoundException; import java.io.FileReader; import java.io.IOException; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; import java.util.ArrayList; import java.util.List;
 @WebFilter("/testServlet")
public class SensitiveWordsFilter implements Filter {
public void destroy() {
}

public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
    //      ,  getPatameter  
   ServletRequest proxy_req= (ServletRequest) Proxy.newProxyInstance(req.getClass().getClassLoader(), req.getClass().getInterfaces(), new InvocationHandler() {
        @Override
        public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        
           //  getParameter  
            //     getParameter  
            if (method.getName().equals("getParameter")){
        
                //     
                //     
                String value= (String) method.invoke(req,args);
                if (value!=null){
                    for (String str:sensitive){
                        if (value.contains(str)){
                            value=value.replaceAll(str,"***");
                        }
                    }
                }
                return value;
            }
            return method.invoke(req,args);
        }
    });

    //  
    chain.doFilter(proxy_req, resp);

}

//      
private List sensitive =new ArrayList();
public void init(FilterConfig config) throws ServletException {
    try {

        //    
        //        
        ServletContext servletContext=config.getServletContext();
        String realPath=servletContext.getRealPath("/WEB-INF/classes/    .txt");

        //    
        BufferedReader br =new BufferedReader(new FileReader(realPath));

        //            list 
        String line=null;
        while ((line=br.readLine())!=null){
            sensitive.add(line);
        }
        br.close();
        System.out.println(sensitive);
    } catch (Exception e) {
        e.printStackTrace();
    }
}

}