struts2動態調用+Servlet過濾器+struts2攔截器

来源:http://www.cnblogs.com/wujingtaocoding/archive/2017/12/03/7967634.html
-Advertisement-
Play Games

周末真的是懶到心慌。。。。。。 本文是在完整s2sh項目基礎上添加的,不太瞭解s2sh項目構建的朋友可以先參考一下這幾篇文章: eclipse環境下基於tomcat-7.0.82構建struts2項目 eclipse環境下基於已構建struts2項目整合spring+hibernate 基於已構建S ...


周末真的是懶到心慌。。。。。。

本文是在完整s2sh項目基礎上添加的,不太瞭解s2sh項目構建的朋友可以先參考一下這幾篇文章:

eclipse環境下基於tomcat-7.0.82構建struts2項目

eclipse環境下基於已構建struts2項目整合spring+hibernate

基於已構建S2SH項目配置全註解方式簡化配置文件

首先簡單說明一下為什麼需要在s2sh項目中配置題目所述三項:

1.struts2動態調用:

如果不配置動態調用,我們只能在一個action中調用一個預設excute()方法,每請求調用一個方法就需要編寫一個action,這樣就會加大開發的工作量,因此這是剛需。

2.Servlet過濾器

Servlet過濾器我們可以理解為一個獨立的web組件,它攔截請求和響應,以便查看、提取或以某種方式操作正在客戶機和伺服器之間交換的數據。過濾器是通常封裝了一些功能的 Web 組件,這些功能雖然很重要,但是對於處理客戶機請求或發送響應來說不是決定性的。

3.struts2攔截器

struts2攔截器是是其核心,攔截器可以讓我們在action和result執行之前或者之後完成一些操作,比如許可權驗證,未登陸的用戶不被允許訪問某些資源等。

過濾器與攔截器的區別

首先過濾器是基於servlet的基礎上進行的操作,是屬於全局的,可過濾到所有請求資源,包括.css等文件,而攔截器是基於struts2的,只能過濾到請求action的方法。

相同點,二者的實現都可看作是模塊化的,可理解為是aop的一種策略。

配置步驟:

第一步:配置struts2動態調用

在struts.xml配置文件中的<struts></struts>節點內聲明struts2支持動態調用、並規定匹配怎樣的字元交給struts2進行處理,代碼如下:

    <!-- 讓struts2支持動態方法調用 以感嘆號方式調用action中的多個方法 -->
    <constant name="struts.enable.DynamicMethodInvocation" value="true" />

    <!-- 所有匹配*.action、do的請求都由struts2處理 -->
    <constant name="struts.action.extension" value="action,do" />

第二步:配置servlet過濾器

過濾器的配置需要我們實現servlet的Filter介面,並實現其抽象方法destroy()、doFilter(ServletRequest arg0, ServletResponse arg1,FilterChain arg2)、init(FilterConfig arg0),三個方法含義分別是初始化、過濾操作、銷毀,接著需要我們在web.xml進行聲明自定義過濾器,因為web.xml才是servlet的第一容器,給出自定義過濾器代碼如下:

package wjt.com.test.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 CharacterFilter implements Filter{

    @Override
    public void destroy() {
        // TODO Auto-generated method stub
        
    }

    @Override
    public void doFilter(ServletRequest arg0, ServletResponse arg1,
            FilterChain arg2) throws IOException, ServletException {
        System.out.println("過濾器...");
        arg2.doFilter(arg0, arg1);
    }

    @Override
    public void init(FilterConfig arg0) throws ServletException {
        // TODO Auto-generated method stub
        
    }

}

修改後的web.xml如下:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
  <display-name>SSHDemo</display-name>
  
      <!-- spring的監聽器配置開始 -->
    <!-- spring監聽器的作用:提供實例(IOC) -->
      <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:applicationContext.xml</param-value>
    </context-param>
    
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    
        <!--過濾非法字元,該配置必須在最前面 -->
    <filter>
        <filter-name>characterFilter</filter-name>
        <filter-class>wjt.com.test.filter.CharacterFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>UTF-8</param-value>
        </init-param>
    </filter>
    <filter-mapping>   <!-- 指定過濾器映射 -->
        <filter-name>characterFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
  
  <!-- 將請求路徑交由struts過濾 -->
  <filter>
        <filter-name>struts2</filter-name>
        <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>struts2</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
</web-app>

 

第三步:配置struts2攔截器

struts2的攔截器介面有多個,根介面也包含初始化、執行攔截操作、銷毀三個抽象方法,這裡我們繼承MethodFilterInterceptor抽象類,該類內部已經對初始化和銷毀的方法進行了實現,因此只需要實現執行攔截操作的抽象方法即可,當然如果有初始化和銷毀操作,我們這裡也可以對其進行定義覆蓋父類同名方法的實現,代碼如下:

package wjt.com.test.interceptor;

import org.apache.struts2.ServletActionContext;

import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.MethodFilterInterceptor;

/**
 * 自定義方法攔截器
 * 
 * @author Together
 *
 */
public class MethodInterceptor extends MethodFilterInterceptor{

    /**
     * 
     */
    private static final long serialVersionUID = 1L;

    @Override
    protected String doIntercept(ActionInvocation arg0) throws Exception {
        System.err.println("攔截器生效...");
        String action=(String) ServletActionContext.getRequest().getSession().getAttribute("action");
        System.out.println("action:"+action);
        StringBuffer requstPath=ServletActionContext.getRequest().getRequestURL();
        System.out.println("requstPath:"+requstPath);
        System.err.println("攔截器結束...");
        return arg0.invoke();
    }

}

配置struts.xml文件,使攔截器生效,配置如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
            "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
            "http://struts.apache.org/dtds/struts-2.3.dtd"><!-- 這裡要和struts2版本號統一 -->

<struts>

    <!-- 告知Struts2運行時使用Spring來創建對象 -->
    <constant name="struts.objectFactory" value="spring" />

    <!-- 讓struts2支持動態方法調用 以感嘆號方式調用action中的多個方法 -->
    <constant name="struts.enable.DynamicMethodInvocation" value="true" />

    <!-- 所有匹配*.action、do的請求都由struts2處理 -->
    <constant name="struts.action.extension" value="action,do" />

    <package name="default" namespace="/" extends="struts-default">

        <interceptors>

            <!-- 先定義攔截器 -->
            <interceptor name="myInterceptor" class="wjt.com.test.interceptor.MethodInterceptor">
                <!-- 指定系統初始化給攔截器的參數 -->
                <!-- <param name="hello">吳靜濤</param> -->
            </interceptor>

            <!-- 加到自己設置的攔截器棧裡邊去 -->
            <interceptor-stack name="myStack">
                <interceptor-ref name="myInterceptor"></interceptor-ref>
                <interceptor-ref name="defaultStack"></interceptor-ref>
            </interceptor-stack>

        </interceptors>

        <!-- 改變系統預設的攔截器,改成自己的預設攔截器,並且一個系統只能有一個預設的攔截器,這樣這個攔截器棧會預設應用到所有的Action上去 -->
        <default-interceptor-ref name="myStack" />

    </package>

</struts>

配置action實現類,若使對action實現類的請求經過自定義攔截器的處理,需要我們對其添加@ParentPackage("default"),該註解添加到action類名上方,作為action的第一註解存在。

測試:

到這裡題目所屬三項配置就完畢了,啟動項目並請求action後截圖如下所示表示配置成功:

 

這裡只給出簡單配置,讀者朋友最好還是在理解原理的前期下使用,本人還是剛畢業小白,對原理的理解還不夠深,還沒能達到陳述原理的水平,有不合理的地方還請大家指出。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 慕課網實戰教程後端:1、java c++演算法與數據結構2、java Spring Boot帶前後端 漸進式開發企業級博客系統3、java Spring Boot企業微信點餐系統4、java Spring Security開發安全的REST服務5、Java Spring帶前後端開發完整電商平臺6、Ja ...
  • 在python進行像b = a這樣的賦值時,只會創建一個對a的新引用,使a的引用計數加1,而不會創建新的對象: 這樣,當引用的對象是可變對象的時候(列表,字典,可變集合等),會產生意料之外的行為: 因為a和b引用的是同一對象,改變其中一個,另外一個也會隨之改變。當我們想建立一個副本而不是引用時,可以 ...
  • 前言 上篇SSM框架環境搭建篇,演示了我們進行web開發必不可少的一些配置和準備工作,如果這方面還有疑問的地方,可以先參考上一篇“SSM框架開發web項目系列(一) 環境搭建篇”。本文主要介紹MyBatis的基礎內容,包括基本概念、開發步驟、使用實例等。說起MyBatis,工作中做過SSH/SSM相 ...
  • 簡介: 割邊和割點的定義僅限於無向圖中。我們可以通過定義以蠻力方式求解出無向圖的所有割點和割邊,但這樣的求解方式效率低。Tarjan提出了一種快速求解的方式,通過一次DFS就求解出圖中所有的割點和割邊。 歡迎探討,如有錯誤敬請指正 如需轉載,請註明出處 http://www.cnblogs.com/ ...
  • 本文涉及到的知識:Struts2超鏈接的使用、Struts遍歷List、${pageContext.request.contextPath} 不能出現在Struts2標簽中。 ...
  • 前言 為何使用Python Python 是一種效率極高的語言。與其他眾多的語言相比,實現相同功能,使用Python編寫的程式包含的代碼更少。Python的語法簡單,易上手,使用Python編寫的代碼更容易閱讀、調試和擴展。 Python使用領域也比較多。Python應用領域有:雲計算、人工智慧、大 ...
  • 隨筆之java匿名內部類 從今天起開始每日一篇技術博客,當然這隻是我當天所學的一些隨筆,裡面或多或少會有理解不當的地方,希望大家多多指教,一起進步! 在講匿名內部類之前,先講講內部類的一些概念。 1.內部類:顧名思義,內部類就是寫在一個類裡面的類(廢話),這裡大家可能會問了,為什麼我們不直接寫一個c ...
  • 三、tornado.web.Application 1、Application:tornado.web.Aplication新建一個應用,可通過直接實例化這個類或實例化它的子類來新建應用; 2、handlers:實例化時至少需要傳入參數handlers,handlers為元素為元組的列表,元組中第一 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...