1. 程式人生 > >JavaEE學習筆記之SSH—Struts2(1)

JavaEE學習筆記之SSH—Struts2(1)

現在來學習SSH中的第二個框架——Struts2

一、strust2框架來歷簡介:

WebWork是由OpenSymphony組織開發的,致力於元件化和程式碼重用的J2EE Web框架。(同時也是一個成熟的基於Web的MVC框架)

MVC:Model View Controller, model是模型,view是檢視,controller是控制器,是一種框架模式.

隨著WebWork框架的發展,衍生出了strust2框架,因此strust2框架是WebWork的升級,而不是一個全新的框架,因此穩點性、效能等方面都有很好的保證,而且也同時吸收了struts1框架和WebWork倆者的優點.所以strust2框架也是一個基於Web的MVC框架

注意:strust2框架並不是struts1框架的延續或者升級,倆者有著很大的不同

二、web專案中的三層架構(和MVC是兩個完全不同的架構)

   1.表示層(檢視層)
    Struts2框架就是工作在這個地方

   2.業務邏輯層
    service層,處理業務邏輯,比如判斷使用者名稱是否存在、密碼是否正確、許可權是否擁有、賬號是否被凍結、賬號是否異常、使用者積分是否到達操作要求等等,多為一些執行某一個操作條件的判斷

   3.資料訪問層
    dao層,專門處理和資料庫進行交換的事情,jdbc/hibernate就在這裡使用

在專案中,這些不同的分層的表現形式,其實就是在我們自己建的不同的package中寫上各自分層中所使用的java類.比如在專案中我們建了三個package,三個package中java類的作用分別為表示層的程式碼、業務邏輯層程式碼、資料訪問層程式碼.
注意:可以理解為,MVC架構是這裡說描述的三層架構的一部分,即:三層架構中的表示層可以使用mvc架構的框架來實現,例如使用struts2框架.

三、使用struts2框架的好處(為什麼要使用struts2框架)

減少程式設計人員程式碼的編寫,使程式碼更加簡潔明瞭,縮短開發時間,增加開發效率.

首先將Struts2的框架搭建起來:

1)獲取釋出包

可以從 Struts2官網、Apache、GitHub等,當然直接百度肯定也是可以的。

2)匯入相關 jar 包

將 struts-2.3.24.1-all\struts-2.3.24.1\apps\struts2-blank.war 壓縮檔案解壓,然後將 E:\utils\struts2\struts-2.3.24.1-all\struts-2.3.24.1\apps\struts2-blank\WEB-INF\lib 下的 jar 包全部匯入到專案中 WebContent/WEB-INF/lib 中。
(13個)
這裡寫圖片描述


struts2-core-2.3.24.1.jar
xwork-core-2.3.24.1.jar
這兩個是核心 jar 包

3)配置 web.xml

  <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>*.action</url-pattern>
  </filter-mapping>

在web.xml檔案中配置struts2框架的過濾器。這個過濾器的作用:攔截struts2框架中的action.
注意:如果不配置這個filter,struts2框架就不能夠工作.

4)配置 struts2 核心配置檔案 struts.xml

將 struts-2.3.24.1\apps\struts2-blank\WEB-INF\src\java\struts.xml 複製到專案的 src 目錄下。

<?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">
        <struts>
            <constant name="struts.enable.DynamicMethodInvocation" value="false" />
            <constant name="struts.devMode" value="true" />
            <package name="default" namespace="/" extends="struts-default">

            </package>
        </struts>

這樣 Struts2 框架就搭建好了。

如果在 struts.xml 中不能夠提示或者與警告什麼的,那有可能是 dtd沒有導進來。

解決辦法:

a、先將 struts-2.3.24.1\apps\struts2-blank\WEB-INF\lib 下的 struts2-core-2.3.24.1.jar 解壓開。

b、再在 struts-2.3.24.1\apps\struts2-blank\WEB-INF\lib\struts2-core-2.3.24.1\ 中找到 struts-2.3.dtd 檔案複製到 專案中的 WEB-INF 下。

c、windows ——> preferences ——> 輸入 xml 搜尋 ——> XML Catalog ——> Add

這裡寫圖片描述

點選 WorkSpace...從專案中找到 struts-2.3.dtd ——> OK

Key type: 選擇 URI

key:輸入 http://struts.apache.org/dtds/struts-2.3.dtd

這樣就應該有提示了,也不會有警告了。

Struts2工作原理

在struts2的應用中,從使用者請求到伺服器返回相應響應給客戶端的過程中,包含了許多元件如:Controller、ActionProxy、ActionMapping、Configuration Manager、ActionInvocation、Inerceptor、Action、Result等。下面我們來具體看看這些元件有什麼聯絡,它們之間是怎樣在一起工作的。
這裡寫圖片描述
(1) 客戶端(Client)向Action發用一個請求(Request)

(2) Container通過web.xml對映請求,並獲得控制器(Controller)的名字

(3) 容器(Container)呼叫控制器(StrutsPrepareAndExecuteFilter或FilterDispatcher)。在Struts2.1以前呼叫FilterDispatcher,Struts2.1以後呼叫StrutsPrepareAndExecuteFilter

(4) 控制器(Controller)通過ActionMapper獲得Action的資訊

(5) 控制器(Controller)呼叫ActionProxy

(6) ActionProxy讀取struts.xml檔案獲取action和interceptor stack的資訊。

(7) ActionProxy把request請求傳遞給ActionInvocation

(8) ActionInvocation依次呼叫action和interceptor

(9) 根據action的配置資訊,產生result

(10) Result資訊返回給ActionInvocation

(11) 產生一個HttpServletResponse響應

(12) 產生的響應行為傳送給客服端。

四、struts2框架中的Action

struts2框架中有一種java類叫做Action,這種說法就像J2EE專案中有一種java類加Servlet.(人們的生活中有一種人的職業叫警察)struts2框架底層還是封裝了Servlet的相關內容而實現出來的.只不過struts2框架除了servlet的功能以外還擴展出了很多其他的功能,同時還大大簡化了以前在servlet中繁瑣的操作.

在struts2框架中有一種類就是用來代替以前我們在web專案中所使用到的servlet,那麼這種類,在struts2框架中被稱為Action.所以Action其實也是一種java類,比servlet功能更加強大的java類,同時還比servlet中的操作簡單.

五.為什麼Action會有比servlet強大的功能以及簡潔的操作

因為我們在web.xml檔案中配置了struts2框架中專門的過濾器,用作攔截訪問action的請求,攔截住之後,struts2框架就可以給Action新增很多豐富的功能了.

開發 Struts2 專案:

1、搭建好 Struts2 框架

2、編寫 Action

3、配置 Struts.xml

舉個例子來講:

新建個類為 UserAction.java

public class UserAction {

    public String toLogin() {
        System.out.println("跳轉到登陸頁面");
        return "login";
    }
    public String toRegister() {
        System.out.println("跳轉到註冊頁面");
        return "register";
    }
}

現在 struts.xml 的配置為

<package name="test" namespace="/"  extends="struts-default">
        <!-- action相當於以前的Servlet的概念,對應一個請求 name的為請求的url地址 
                localhost:8088/專案名/user_toLogin.action-->
        <!-- 直接匹配 -->
        <action name="user_*" class="com.briup.week3.web.action.UserAction" method="{1}">
            <result name="login">/WEB-INF/jsp/login.jsp</result>
            <result name="register">/WEB-INF/jsp/register.jsp</result>
        </action>
①首先容器會建立 request 物件並攜帶 url:/user_toRegister.action;

②然後經過 struts2 的過濾器即
<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>*.action</url-pattern>

就變為 /user_toRegister;

③然後經過 struts.xml 中 
<package name="test" namespace="/"  extends="struts-default">

的 namespace=”/” 就變為 user_toRegister;

④再經過 
<action name="user_*" class="com.briup.week3.web.action.UserAction" method="{1}">

中的 name=”user_*” 就變為 toRegister;

⑤然後將會呼叫這個類(class="com.briup.week3.web.action.UserAction")的 toRegister 方法。只知道類名如何呼叫方法,這將會用到 java 中的反射。

Class.forName(“com.briup.week3.web.action.UserAction.class”)
.newInstance()
.toRegister();
呼叫這個之後將會返回一個字串 “register”

⑥最後拿這個字串去和
<result name="login">/WEB-INF/jsp/login.jsp</result>
            <result name="register">/WEB-INF/jsp/register.jsp</result>
        </action>

中的 name 匹配,將匹配到第二個 result ——> 跳轉到 /WEB-INF/jsp/register.jsp 這個頁面。

在 struts.xml 中,有一個標籤叫做

<constant name="struts.devMode" value="true"></constant>

當然這裡面的常量 name 有許多值,那這些都是從哪裡來呢,我們可以開啟 struts2-core-2.3.29.jar/org/apache/struts2/default.properties,當中就寫了好多配置資訊,都是以鍵值對形式展現。那我們的 constant 標籤的的 name 值就可以從裡面取。

這裡寫圖片描述

常用常量:

<?xml version="1.0" encoding="UTF-8" ?> 
<!DOCTYPE struts PUBLIC   
   "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"   
    "http://struts.apache.org/dtds/struts-2.0.dtd">  

<struts>  
    <!-- 指定Web應用的預設編碼集,相當於呼叫HttpServletRequest的setCharacterEncoding方法 -->  
    <constant name="struts.i18n.encoding" value="UTF-8" />  

    <!--   
        該屬性指定需要Struts 2處理的請求字尾,該屬性的預設值是action,即所有匹配*.action的請求都由Struts2處理。   
        如果使用者需要指定多個請求字尾,則多個字尾之間以英文逗號(,)隔開。   
    -->  
    <constant name="struts.action.extension" value="do" />  

    <!-- 設定瀏覽器是否快取靜態內容,預設值為true(生產環境下使用),開發階段最好關閉 -->  
    <constant name="struts.serve.static.browserCache" value="false" />  

    <!-- 當struts的配置檔案修改後,系統是否自動重新載入該檔案,預設值為false(生產環境下使用),開發階段最好開啟 -->  
    <constant name="struts.configuration.xml.reload" value="true" />  

    <!-- 開發模式下使用,這樣可以打印出更詳細的錯誤資訊 -->  
    <constant name="struts.devMode" value="true" />  

    <!-- 預設的檢視主題 -->  
    <constant name="struts.ui.theme" value="simple" />  

    <!-- spring 託管 -->  
    <constant name="struts.objectFactory" value="spring" />  

    <!--   
        指定載入struts2配置檔案管理器,預設為org.apache.struts2.config.DefaultConfiguration   
        開發者可以自定義配置檔案管理器,該類要實現Configuration介面,可以自動載入struts2配置檔案。   
    -->  
    <constant name="struts.configuration"  
        value="org.apache.struts2.config.DefaultConfiguration" />  

    <!-- 設定預設的locale和字元編碼 -->  
    <constant name="struts.locale" value="zh_CN" />  
    <constant name="struts.i18n.encoding" value="GBK" />  

    <!-- 指定Struts的工廠類 -->  
    <constant name="struts.objectFactory" value="spring"></constant>  

    <!--   
        指定spring框架的裝配模式,裝配方式有: name, type, auto, and constructor (name   
        是預設裝配模式)   
    -->  
    <constant name="struts.objectFactory.spring.autoWire" value="name" />  

    <!-- 該屬性指定整合spring時,是否對bean進行快取,值為true or false,預設為true -->  
    <cosntant name="struts.objectFactory.spring.useClassCache" />  

    <!-- 指定型別檢查,包含tiger和notiger -->  
    <cosntant name="struts.objectTypeDeterminer" value="tiger" />  

    <!-- 該屬性指定處理 MIME-type multipart/form-data,檔案上傳 -->  
    <constant name="struts.multipart.parser" value="cos" />  
    <constant name="struts.multipart.parser" value="pell" />  
    <constant name="struts.multipart.parser" value="jakarta" />  

    <!-- 指定上傳檔案時的臨時目錄,預設使用 javax.servlet.context.tempdir -->  
    <constant name="struts.multipart.saveDir" value="/tmpuploadfiles" />  

    <!-- 該屬性指定Struts 2檔案上傳中整個請求內容允許的最大位元組數 -->  
    <constant name="struts.multipart.maxSize" value="2097152" />  

    <!--   
        該屬性指定Struts2應用載入使用者自定義的屬性檔案,該自定義屬性檔案指定的屬性不會覆蓋   
        struts.properties檔案中指定的屬性。如果需要載入多個自定義屬性檔案,多個自定義屬性文   
        件的檔名以英文逗號(,)隔開。(也就是說不要改寫struts.properties!)   
    -->  
    <constant name="struts.custom.properties"  
        value="application,org/apache/struts2/extension/custom" />  

    <!-- 指定請求url與action對映器,預設為org.apache.struts2.dispatcher.mapper.DefaultActionMapper -->  
    <constant name="struts.mapper.class" value="org.apache.struts2.dispatcher.mapper.DefaultActionMapper" />  

    <!-- 指定action的字尾,預設為action -->  
    <constant name="struts.action.extension" value="do" />  

    <!-- 被 FilterDispatcher使用指定瀏覽器是否快取靜態內容,測試階段設定為false,釋出階段設定為true. -->  
    <constant name="struts.serve.static.browserCache" value="true" />  

    <!-- 設定是否支援動態方法呼叫,true為支援,false不支援. -->  
    <constant name="struts.enable.DynamicMethodInvocation" value="true" />  

    <!-- 設定是否可以在action中使用斜線,預設為false不可以,想使用需設定為true. -->  
    <constant name="struts.enable.SlashesInActionNames" value="true" />  

    <!-- 是否允許使用表示式語法,預設為true. -->  
    <constant name="struts.tag.altSyntax" value="true" />  

    <!-- 設定當struts.xml檔案改動時,是否重新載入 -->  
    <cosntant name="struts.configuration.xml.reload" value="true" />  

    <!-- 設定struts是否為開發模式,預設為false,測試階段一般設為true. -->  
    <cosntant name="struts.devMode" value="true" />  

    <!-- 設定是否每次請求,都重新載入資原始檔,預設值為false. -->  
    <cosntant name="struts.i18n.reload" value="false" />  

    <!-- 標準的UI主題,預設的UI主題為xhtml,可以為simple,xhtml或ajax -->  
    <cosntant name="struts.ui.theme" value="xhtml" />  

    <!-- 模板目錄 -->  
    <cosntant name="struts.ui.templateDir" value="template" />  

    <!-- 設定模板型別. 可以為 ftl, vm, or jsp -->  
    <cosntant name="struts.ui.templateSuffix" value="ftl" />  

    <!-- 定位velocity.properties 檔案. 預設velocity.properties -->  
    <cosntant name="struts.velocity.configfile" value="velocity.properties" />  

    <!-- 設定velocity的context. -->  
    <cosntant name="struts.velocity.contexts" value="...." />  

    <!-- 定位toolbox -->  
    <cosntant name="struts.velocity.toolboxlocation" value="...." />  

    <!-- 指定web應用的埠 -->  
    <cosntant name="struts.url.http.port" value="80" />  

    <!-- 指定加密埠 -->          
    <cosntant name="struts.url.https.port" value="443" />  

    <!-- 設定生成url時,是否包含引數.值可以為: none,get or all -->  
    <cosntant name="struts.url.includeParams" value="get" />  

    <!-- 設定要載入的國際化資原始檔,以逗號分隔. -->  
    <cosntant name="struts.custom.i18n.resources" value="application" />  

    <!-- 對於一些web應用伺服器不能處理HttpServletRequest.getParameterMap(),   
        像 WebLogic,Orion, and OC4J等,須設定成true,預設為false. -->  
    <cosntant name="struts.dispatcher.parametersWorkaround" value="false" />     

    <!-- 指定freemarker管理器 -->  
    <cosntant name="struts.freemarker.manager.classname" value="org.apache.struts2.views.freemarker.FreemarkerManager" />    

    <!-- 設定是否對freemarker的模板設定快取,效果相當於把template拷貝到 WEB_APP/templates. -->  
    <cosntant name="struts.freemarker.templatesCache" value="false" />       

    <!-- 通常不需要修改此屬性. -->  
    <cosntant name="struts.freemarker.wrapper.altMap" value="true" />    

    <!-- 指定xslt result是否使用樣式表快取.開發階段設為true,釋出階段設為false. -->  
    <cosntant name="struts.xslt.nocache" value="false" />    

    <!-- 設定struts自動載入的檔案列表. -->  
    <cosntant name="struts.configuration.files" value="struts-default.xml,struts-plugin.xml,struts.xml" />  

    <!-- 設定是否一直在最後一個slash之前的任何位置選定namespace. -->  
    <cosntant name="struts.mapper.alwaysSelectFullNamespace" value="false" />  
</struts>