Struts2框架之struts.xml詳解

Struts2框架之struts.xml詳解

[TOC]

一個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">

<struts>

    <!-- 聲明常量 -->
    <constant name="struts.i18n.encoding" value="UTF-8"></constant> <!-- 可以幫助我們解決post請求亂碼問題 -->
    <!-- <constant name="struts.action.extension" value="action"></constant> --><!-- 指定訪問strtsu2框架路徑的擴展名 -->
    <constant name="struts.devMode" value="true"></constant>
    <!-- 配置這項后,它會提供更加詳細報錯信息,以及在struts.xml文件修改后不在需要重啟服務器 -->

    <constant name="struts.enable.DynamicMethodInvocation" value="true"></constant><!-- 
        開啟動態(tài)方法調用 -->

    <package name="default" namespace="/" extends="struts-default">
        <global-results>
            <result name="" type=""></result>
        </global-results>
    
        <action name="struts2" class="cn.thc.web.action.Struts2Action"></action>

        <action name="login" class="cn.thc.web.action.LoginAction"
            method="login">
            <result name="success" type="redirect">/success.jsp</result>
            <result name="failer">/failer.jsp</result>
        </action>

        <action name="login1" class="cn.thc.web.action.LoginAction1"
            method="login">
            <result name="success" type="redirect">/success.jsp</result>
            <result name="failer">/failer.jsp</result>
        </action>
        <action name="login2" class="cn.thc.web.action.LoginAction2"
            method="login">
            <result name="success" type="redirect">/success.jsp</result>
            <result name="failer">/failer.jsp</result>
        </action>

        <action name="test">
            <result>/success.jsp</result>
        </action>

        <!-- <action name="bookadd" class="cn.thc.web.action.BookAction" method="addBook"></action> 
            <action name="bookupdate" class="cn.thc.web.action.BookAction" method="updateBook"></action> 
            <action name="bookdel" class="cn.thc.web.action.BookAction" method="delBook"></action> 
            <action name="bookfind" class="cn.thc.web.action.BookAction" method="findBook"></action> -->
        <!-- 以上操作可以簡化,使用*通配置來操作 -->
        <!-- <action name="*_*" class="cn.thc.web.action.{1}Action" method="{2}"></action> -->
    </package>
</struts>


package標簽的配置

  1. name屬性,作用是定義一個包的名稱,它必須唯一.即在struts.xml中可以配置多個package,但這些package的name不可以重復. package是用來管理action的.
  2. namespace屬性, 作用是與action標簽的name屬性聯(lián)合使用來確定一個action的訪問路徑.
    例如在jsp中的form表單的action如下
    action="${pageContext.request.contextPath}/login.action"
    那么在package標簽的namespace配置了"/"
    在action標簽中的name屬性配置了"login". 那么該form表單即可對這個action進行訪問了.
  3. extends屬性, 作用是指定繼承哪個包. 可以把struts的package類比為java中的一個類,那么java中的類是可以繼承父類的屬性和方法的. 類似的,繼承了某個包,那么就代表繼承的包的配置也就生效了.
    一般是繼承struts-default.
    struts-default包是在struts-default.xml中聲明的.
    struts-default.xml是在struts2-core的jar包中的


  4. abstract屬性, 可以在上面的截圖中看到struts-default包有abstract屬性, 并且為true, 代表這個包是抽象的.
    類似于java中的抽象類, 是不能創(chuàng)建對象的,必須有其子類繼承了抽象類才能調用抽象類中的成員變量和方法.
    那么在包中寫abstract為true,代表當前的包是抽象的, 主要是用于被其他包繼承的.

action標簽的配置

  1. name屬性, 作用是與package的namespace聯(lián)合使用來確定一個action的訪問路徑
  2. class屬性, 作用是指示當前訪問的action類.
  3. method屬性, 用于指示當前的action類中的哪個方法執(zhí)行.

result標簽的配置

主要作用是指示結果視圖的.

  1. name屬性, 作用是與action類的method方法返回值進行匹配, 來確定跳轉的路徑的. name中的值為方法的返回值, result的標簽體為跳轉的jsp
  2. type屬性, 作用是指定該方法的跳轉方式, 默認的是請求轉發(fā).
    如果值為type="redirect" 代表重定向到某個jsp.
    如果值為redirectAction代表重定向到某個action中.

關于action標簽配置的默認值

先來做一個實驗, 在struts.xml中編寫如下的action訪問映射

<action name="test">
     <result>/success.jsp</result>
</action>
  • 可以看到在上面的action標簽的配置中,是沒有寫class和method屬性的.
    <result>標簽也沒有寫name屬性的值.
  • 這個時候,啟動項目,在瀏覽器上訪問http://localhost:8080/項目名/test
    發(fā)現(xiàn)是可以跳轉到success.jsp頁面的.
  • 原因首先是該包繼承了extends="struts-default"
    struts-default包是在struts-default.xml文件中的,有定義一個默認的class
<default-class-ref class="com.opensymphony.xwork2.ActionSupport" />

會執(zhí)行ActionSupport類的如下的execute方法

 public String execute() throws Exception {
        return SUCCESS;
    }
 /**
     * The action execution was successful. Show result
     * view to the end user.
     */
    public static final String SUCCESS = "success";

從該方法中可以看到,不執(zhí)行任何的業(yè)務邏輯代碼,返回success常量.
也就說明了,class的默認值是com.opensymphony.xwork2.ActionSupport
method的默認值是execute, 即默認訪問的是excuse方法.
默認的跳轉方式是dispatcher請求轉發(fā).

  • 如果在action標簽中,有配置了自己寫的類,但是這個類沒有寫execute方法,在配置action標簽的時候,也沒有寫method屬性,那么會報如下的異常
    NoSuchMethodException 表示你當前的的類中沒有寫execute方法. 寫上方法,就不會報異常了.
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

友情鏈接更多精彩內容