在Web應用中可以使用過濾器對所有的訪問和請求進行統一的處理、IP訪問限制以及用戶發送請求的字符編碼轉換等,在進行具體的業務邏輯處理之前,首先要經過過濾器的同意處理,然后才開始進入真正的邏輯處理階段。
過濾器的基本原理
過濾器的功能就是在服務器和酷虎中間增加了一個中間層,可以對兩者之間的交互進行統一的處理,每一個從客戶端提交的請求都需要通過過濾器的處理然后再進行其他操作。
在實際開發過程中,過濾器可以用來對用戶進行統一的身份判斷、IP訪問限制、用戶發送請求的字符編碼轉換、對請求和響應進行加密和解密、記錄用戶登錄日志等。當然過濾的用途不僅僅這些,我們可以根據過濾器的實現原理,思考過濾器的更多用途。
SetCharacterEncodingFilter.java
package filter; 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; public class SetCharacterEncodingFilter implements Filter { private String edcoding = null; private FilterConfig filterConfig = null; private boolean ignore = true; public void destroy() { edcoding = null; filterConfig = null; } public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain) throws IOException, ServletException { if (ignore == true || request.getCharacterEncoding() == null) { String encoding = setCharacterEncoding(request); if (encoding != null) { request.setCharacterEncoding(encoding); } } filterChain.doFilter(request, response); } public void init(FilterConfig filterConfig) throws ServletException { this.filterConfig = filterConfig; this.edcoding = filterConfig.getInitParameter("encoding"); String value = filterConfig.getInitParameter("ignore"); if (value == null) { this.ignore = true; } else if (value.equalsIgnoreCase("true")) { this.ignore = true; } else { this.ignore = false; } } public String setCharacterEncoding(ServletRequest request) { return this.edcoding; } }
web.xml中加以下代碼
<filter> <filter-name>SetCharacterEncodingFilter</filter-name> <filter-class>filter.SetCharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>SetCharacterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>