<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                七、過濾器技術應用節點訓練 1.&nbsp;掌握Filter的概念及作用 2.&nbsp;掌握編寫過濾器的語法 3.&nbsp;掌握Filter的配置方法 4.&nbsp;掌握多個過濾器的執行順序 ## **Filter&Listener** ### **學習目標** 1.理解并掌握如何編寫一個Filter(過濾器) 2.理解并掌握Filter的各項配置 3.理解并完成登陸驗證案例和過濾敏感詞匯案例 4.理解并掌握動態代理增強某個方法 5.理解并掌握ServletContextListener監聽器 ### **課程內容** 1.Filter快速入門 2.Filter在web.xml中的各項配置 3.Filter的執行流程和生命周期 4.Filter攔截路徑配置 5.登陸驗證案例 6.敏感詞匯案例 7.動態代理 8.ServletContextListener ## 今日內容 1. Filter:過濾器 2. Listener:監聽器 # Filter:過濾器 1. 概念: * 生活中的過濾器:凈水器,空氣凈化器,土匪、 * web中的過濾器:當訪問服務器的資源時,過濾器可以將請求攔截下來,完成一些特殊的功能。 * 過濾器的作用: * 一般用于完成通用的操作。如:登錄驗證、統一編碼處理、敏感字符過濾... 2. 快速入門: 1. 步驟: 1. 定義一個類,實現接口Filter 2. 復寫方法 3. 配置攔截路徑 1. web.xml 2. 注解 2. 代碼: @WebFilter("/*")//訪問所有資源之前,都會執行該過濾器 public class FilterDemo1 implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { } @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { System.out.println("filterDemo1被執行了...."); //放行 filterChain.doFilter(servletRequest,servletResponse); } @Override public void destroy() { } } 3. 過濾器細節: 1. web.xml配置 <filter> <filter-name>demo1</filter-name> <filter-class>cn.baishenghua.web.filter.FilterDemo1</filter-class> </filter> <filter-mapping> <filter-name>demo1</filter-name> <!-- 攔截路徑 --> <url-pattern>/*</url-pattern> </filter-mapping> 2. 過濾器執行流程 1. 執行過濾器 2. 執行放行后的資源 3. 回來執行過濾器放行代碼下邊的代碼 3. 過濾器生命周期方法 1. init:在服務器啟動后,會創建Filter對象,然后調用init方法。只執行一次。用于加載資源 2. doFilter:每一次請求被攔截資源時,會執行。執行多次 3. destroy:在服務器關閉后,Filter對象被銷毀。如果服務器是正常關閉,則會執行destroy方法。只執行一次。用于釋放資源 4. 過濾器配置詳解 * 攔截路徑配置: 1. 具體資源路徑: /index.jsp 只有訪問index.jsp資源時,過濾器才會被執行 2. 攔截目錄: /user/* 訪問/user下的所有資源時,過濾器都會被執行 3. 后綴名攔截: *.jsp 訪問所有后綴名為jsp資源時,過濾器都會被執行 4. 攔截所有資源:/* 訪問所有資源時,過濾器都會被執行 * 攔截方式配置:資源被訪問的方式 * 注解配置: * 設置dispatcherTypes屬性 1. REQUEST:默認值。瀏覽器直接請求資源 2. FORWARD:轉發訪問資源 3. INCLUDE:包含訪問資源 4. ERROR:錯誤跳轉資源 5. ASYNC:異步訪問資源 * web.xml配置 * 設置<dispatcher></dispatcher>標簽即可 5. 過濾器鏈(配置多個過濾器) * 執行順序:如果有兩個過濾器:過濾器1和過濾器2 1. 過濾器1 2. 過濾器2 3. 資源執行 4. 過濾器2 5. 過濾器1 * 過濾器先后順序問題: 1. 注解配置:按照類名的字符串比較規則比較,值小的先執行 * 如: AFilter 和 BFilter,AFilter就先執行了。 2. web.xml配置: <filter-mapping>誰定義在上邊,誰先執行 4. 案例: 1. 案例1_登錄驗證 * 需求: 1. 訪問day17_case案例的資源。驗證其是否登錄 2. 如果登錄了,則直接放行。 3. 如果沒有登錄,則跳轉到登錄頁面,提示"您尚未登錄,請先登錄"。 2. 案例2_敏感詞匯過濾 * 需求: 1. 對day17_case案例錄入的數據進行敏感詞匯過濾 2. 敏感詞匯參考《敏感詞匯.txt》 3. 如果是敏感詞匯,替換為 *** * 分析: 1. 對request對象進行增強。增強獲取參數相關方法 2. 放行。傳遞代理對象 * 增強對象的功能: * 設計模式:一些通用的解決固定問題的方式 1. 裝飾模式 2. 代理模式 * 概念: 1. 真實對象:被代理的對象 2. 代理對象: 3. 代理模式:代理對象代理真實對象,達到增強真實對象功能的目的 * 實現方式: 1. 靜態代理:有一個類文件描述代理模式 2. 動態代理:在內存中形成代理類 * 實現步驟: 1. 代理對象和真實對象實現相同的接口 2. 代理對象 = Proxy.newProxyInstance(); 3. 使用代理對象調用方法。 4. 增強方法 * 增強方式: 1. 增強參數列表 2. 增強返回值類型 3. 增強方法體執行邏輯 ## Listener:監聽器 * 概念:web的三大組件之一。 * 事件監聽機制 * 事件 :一件事情 * 事件源 :事件發生的地方 * 監聽器 :一個對象 * 注冊監聽:將事件、事件源、監聽器綁定在一起。 當事件源上發生某個事件后,執行監聽器代碼 * ServletContextListener:監聽ServletContext對象的創建和銷毀 * 方法: * void contextDestroyed(ServletContextEvent sce) :ServletContext對象被銷毀之前會調用該方法 * void contextInitialized(ServletContextEvent sce) :ServletContext對象創建后會調用該方法 * 步驟: 1. 定義一個類,實現ServletContextListener接口 2. 復寫方法 3. 配置 1. web.xml <listener> <listener-class>cn.itcast.web.listener.ContextLoaderListener</listener-class> </listener> * 指定初始化參數<context-param> 2. 注解: * @WebListener **1.練習登陸驗證案例** 需求: 1. 訪問case案例的資源。驗證其是否登錄 2. 如果登錄了,則直接放行。 3. 如果沒有登錄,則跳轉到登錄頁面,提示"您尚未登錄,請先登錄"。 **2.練習過濾敏感詞匯案例** 需求: 1. 對case案例錄入的數據進行敏感詞匯過濾 2. 敏感詞匯參考《敏感詞匯.txt》 3. 如果是敏感詞匯(壞蛋,笨蛋),替換為 *** 分析: 1. 對request對象進行增強。增強獲取參數相關方法 2. 放行。傳遞代理對象 web.xml ``` <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" version="3.1"> </web-app> ```
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看