日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JSP过滤器

發布時間:2025/3/16 javascript 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JSP过滤器 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

JSP?過濾器

Servlet和JSP中的過濾器都是Java類,它們存在的目的如下:

  • 在請求訪問后端資源時攔截它
  • 管理從服務器返回給客戶端的響應

下面列出了多種常用的過濾器類型:

  • 認證過濾器
  • 數據壓縮過濾器
  • 加密過濾器
  • 觸發資源訪問事件的過濾器
  • 圖像轉換過濾器
  • 登錄和驗證過濾器
  • MIME類型鏈過濾器
  • 令牌過濾器
  • 轉換XML內容的XSL/T過濾器

過濾器將會被插入進web.xml文件中,然后映射servlet、JSP文件的名字,或URL模式。部署描述文件web.xml可以在 <Tomcat-installation-directory>\conf 目錄下找到。

當JSP容器啟動網絡應用程序時,它會創建每一個過濾器的實例,這些過濾器必須在部署描述文件web.xml中聲明,并且按聲明的順序執行。


Servlet過濾器方法

一個過濾器就是一個Java類,它實現了javax.servlet.Filter 接口。javax.servlet.Filter接口定義了三個方法:

序號方法?&描述
1 public void doFilter (ServletRequest, ServletResponse, FilterChain)

每當 request/response要通過過濾鏈時容器會調用這個方法,因為客戶端請求鏈尾的資源
2 public void init(FilterConfig filterConfig)

容器調用這個方法來表明一個過濾器被安置在服務中
3 public void destroy()

容器調用這個方法來表明一個過濾器正在從服務中移除

JSP過濾器示例

這個例子將會打印IP地址和每次訪問JSP文件的日期時間。當然,這只是個簡單的例子,讓您了解一些簡單的過濾器用法,但是可以使用這些概念來自行構造更復雜的程序。

// 引入Java包 import java.io.*; import javax.servlet.*; import javax.servlet.http.*; import java.util.*;// 實現 Filter 類 public class LogFilter implements Filter {public void init(FilterConfig config) throws ServletException{// 獲取初始化參數String testParam = config.getInitParameter("test-param"); //打印初始化參數System.out.println("Test Param: " + testParam); }public void doFilter(ServletRequest request, ServletResponse response,FilterChain chain) throws java.io.IOException, ServletException {// 獲取客戶端ip地址 String ipAddress = request.getRemoteAddr();// 輸出ip地址及當前時間System.out.println("IP "+ ipAddress + ", Time "+ new Date().toString());// 傳遞請求道過濾器鏈chain.doFilter(request,response);}public void destroy( ){/* 在Filter實例在服務器上被移除前調用。*/} }

編譯LogFilter.java文件,然后將編譯后的class文件放在<Tomcat安裝目錄>/webapps/ROOT/WEB-INF/classes目錄下。


web.xml文件中的JSP過濾器映射

過濾器被定義,然后映射成一個URL或JSP文件名,與servlet被定義然后映射的方式差不多。在部署描述文件web.xml中,使用<filter>標簽來進行過濾器映射:

<filter><filter-name>LogFilter</filter-name><filter-class>LogFilter</filter-class><init-param><param-name>test-param</param-name><param-value>Initialization Paramter</param-value></init-param> </filter> <filter-mapping><filter-name>LogFilter</filter-name><url-pattern>/*</url-pattern> </filter-mapping>

上述過濾器將會應用在所有servlet和JSP程序中,因為我們在配置中指定了" /*"。您也可以指定一個servlet或JSP路徑,如果您只想要將過濾器應用在少數幾個servlet或JSP程序中的話。

現在,像平常一樣訪問servlet或JSP頁面,您就會發現服務器日志中產生了關于此次訪問的記錄。您也可以使用Log4J記錄器來把日志記錄在其它文件中。


使用多重過濾器

您的網絡應用程序可以定義很多不同的過濾器。現在,您定義了兩個過濾器,AuthenFilter和LogFilter,其它的步驟與前面講的一樣,除非要創建一個不同的映射,就像下面這樣:

<filter><filter-name>LogFilter</filter-name><filter-class>LogFilter</filter-class><init-param><param-name>test-param</param-name><param-value>Initialization Paramter</param-value></init-param> </filter><filter><filter-name>AuthenFilter</filter-name><filter-class>AuthenFilter</filter-class><init-param><param-name>test-param</param-name><param-value>Initialization Paramter</param-value></init-param> </filter><filter-mapping><filter-name>LogFilter</filter-name><url-pattern>/*</url-pattern> </filter-mapping><filter-mapping><filter-name>AuthenFilter</filter-name><url-pattern>/*</url-pattern> </filter-mapping>

過濾器的應用順序

在web.xml中<filter>元素的映射順序決定了容器應用這些過濾器的順序。要反轉應用的順序,您只需要反轉web.xml中<filter>元素的定義順序就行了。

比如,上面的例子會首先應用 LogFilter然后再應用AuthenFilter,但是下面這個例子將會反轉應用的順序:

<filter-mapping><filter-name>AuthenFilter</filter-name><url-pattern>/*</url-pattern> </filter-mapping><filter-mapping><filter-name>LogFilter</filter-name><url-pattern>/*</url-pattern> </filter-mapping>

總結

以上是生活随笔為你收集整理的JSP过滤器的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。