struts2基本配置詳解


 

接上一篇文章,使用maven+eclipse搭建最簡單的struts2的HelloWorld,本篇將主要講strust2的基本配置:

1、web.xml的作用

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>/*</url-pattern>
    </filter-mapping>
復制代碼

1)、通知web服務器(tomcat),只要是/* 的請求路徑,都交由該Filter來處理.

2)、通過解析和反射struts2的核心Filter,實例化后,加載struts2的相關配置文件,如struts.xml

將struts.xml文件解析后,在內存中形成一個JavaBean對象,每次訪問進不需要重新加載,直接訪問內存。

當重新部署時會重新加載struts.xml形成新的JavaBean對象.

舉例:

在外存中:struts.xml

<root>
    <Action name="x" class="y" method="z"/>
 </root>

在內存中:struts.xml解析后形成如下的JavaBean對象

復制代碼
public class Root{
     private Action action;  
}
public class action{
    private String name="x";
    private String class="y";
    private String method="z";    
   setter/getter()..  
}
復制代碼

注意:如果更改了struts.xml里的內容,需要重新部署以完成更新內存中的JavaBean對象。

 2、struts.xml的作用

 將請求,處理類和對應的業務方法通過struts.xml靈活的配置起來。

例:

<action name="HelloWorldAction" class="com.amos.web.action.HelloWorldAction" method="execute"> </action>

請請求HelloWorldAction,與類com.amos.web.action.HelloWorldAction中的execute方法配置起來。

HelloWorldAction(請求)------->com.amos.web.action.HelloWorldAction(類)-------->execute(方法)

當想更改請求名稱為abc時直接在配置文件中的name屬性更改即可,或者更改請求對就類中的其它方法,也只需要更改配置文件中的的方法名即可。如下:

abc(請求)------->com.amos.web.action.HelloWorldAction(類)-------->otherMethod(方法)

3、struts2屬性總結:

<package name="com.amos.web.action" namespace="/" extends="struts-default" >
<action name="HelloWorldAction" class="com.amos.web.action.HelloWorldAction" method="execute"> </action>
</package> 

name="com.amos.web.action"------包名

namespace="/" ------訪問的空間

extends="struts-default"------擴展strust2的內部功能,必須是struts-defaul,默認情況下都要經過18攔截器。

name="HelloWorldAction"------執行路徑

class="com.amos.web.action.HelloWorldAction"------使用全路徑便於反射

method="execute"------需要執行的業務方法,也是通過反射

注意:struts2建議將相關的action類放入同一個package下,如CRUD操作,類似於java中的包和類的關系

4、struts2基本配置詳解

1)、訪問Action的規則

規則:<package>中namespace屬性值拼接上<action>中name標簽,拼接符為"/"

例如,將namespace="/hi/amos",拼接后的url如下:

http://localhost:8080/struts2/hi/amos/HelloWorldAction

測試規則:

當前namespace為'/':

http://localhost:8080/struts2/hi/amos/li/HelloWorldAction  [ok]
http://localhost:8080/struts2/hi/amos/HelloWorldAction [ok]
http://localhost:8080/struts2/hi/HelloWorldAction [ok]
http://localhost:8080/struts2/HelloWorldAction [ok]

當前的namesapce為'/hi':

http://localhost:8080/struts2/hi/amos/li/HelloWorldAction  [ok]
http://localhost:8080/struts2/hi/amos/HelloWorldAction [ok]
http://localhost:8080/struts2/hi/HelloWorldAction [ok]
http://localhost:8080/struts2/HelloWorldAction [NO]

總結:對於action訪問規則(*表示任意的路徑):

*/*/HelloWorldAction可以滿足'/'的namespace

*/hi/*/HelloWorldAction可以滿足'/hi'的namespace,一句話總結就是只要包含namespace,strust2會自動進行匹配.

 另外,namespace默認為"/",不對此屬性賦值也可以。

 2)、<action>中不指定class屬性會是什么結果?

 如上所示,如果不指定class值,那么會返回404狀態值。同時可以看到class屬性的默認值為"com.opensymphony.xwork2.ActionSupport"

不寫class屬性值,為返回正確的結果,必須在<action>加上result屬性,其值必須為"success",如下所示:

復制代碼
<package name="com.amos.web.action" namespace="/" extends="struts-default">
        <action name="HelloWorldAction" method="execute">
            <result name="success">
                suc.jsp
            </result>
        </action>
    </package>
復制代碼

另外,需要將excute方法的返回值更改為"success",如下所示:

    //重寫execute()方法
    public String execute() throws Exception {
        System.out.println("歡迎使用struts2!");
        return "success";
    }

然后在webapp目錄下新建一個suc.jsp,在body中加入"成功!!"運行代碼,結果如下所示:

 由上可知,class屬性值也不是必須的,但建議給class屬性賦值,以避免不必要的麻煩。

 

 代碼參見:https://github.com/amosli/strust2    version 2


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM