我們在聊天的時候的或者留言的時候,有部分詞是不允許發表出來。我們可以採用過濾器實現這個功能。
我們只是簡單利用過濾器實現這個過濾的功能,有些地方沒寫的很全
前台代碼:
<body> <form action="<c:url value='/WordServlet'/>" method="post"> 姓名:<input type="text" name="name"/><br/> 留言內容:<textarea rows="10" cols="10" name="textarea"></textarea><br/> <input type="submit" value="提交"/> </form> </body>
Servlet裡面的代碼:
僅僅只是把從前台收的數據讀取出來。看裡面的敏感詞是都過濾。
代碼:
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String name =request.getParameter("name");//名字String text=request.getParameter("textarea");//瀏覽內容PrintWriter pw =response.getWriter(); pw.println("name="+name);//這裡直接輸出,僅僅只是為了查看能否過濾那些關鍵字。 。 pw.print("內容"+text); }過濾器:
過濾的作用就可以體現了,過濾器的是在客戶端訪問服務器的之間進行攔截的。
我們知道過濾器能夠控制request和response,所以我們能夠對這個進行下手。
從客戶端請求是request,所以我們只需要在半路將其攔截,修改裡面的值就可以實現過濾了。採用了包裝的設計模式;
過濾器代碼:
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest req=(HttpServletRequest) request; MyFilter myf =new MyFilter(req); chain.doFilter(myf, response);//採勇我們加強的類的request,傳給後面的servlet使用}自己手動寫一個myFilter類來修改裡面我們需要用到的函數。
class MyFilter extends HttpServletRequestWrapper{ //這是採用包裝模式public MyFilter(HttpServletRequest request) { super(request); } @Override //從寫這個方法public String getParameter(String name) { String words =super.getParameter(name); System.out.println(words);//過濾前的文字List<String> list=WordUtils.getword(); for(String ll:list){ words=words.replace(ll, "*");//敏感詞彙採用**代替} return words; }為了方便維護,我們的敏感詞彙的獲取專門寫了一個工具,方便取,當然也方便管理員添加進去。
public class WordUtils { //採用單例模式private static List<String> list =new ArrayList<String>();//我們可以從這訪問數據庫中存的敏感詞彙,封裝成list返回static {//手動添加幾個list.add("坑貨"); list.add("罵人"); list.add("傻逼"); } public static List<String> getword(){ return list; } public static void addWord(String name){ list.add(name); } public static void sava(){ //這裡可以list裡面的數據存到數據庫中,方便維護,當然也可以寫增刪改查等}在這裡,只要含有這個詞的,全部會變成*
效果圖;
總結:過濾器的強大,可以修改request和response對像一起,你需要調什麼函數,我們就可以採用包裝設計模式的方式修改這個函數,變成我們想要的效果,這個和代理設計模式有點類似。
以上所述是小編給大家介紹的使用JavaEE filter 過濾敏感詞的方法的相關知識,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!