struts2環境搭建及處理流程概要

 當然我們首先要下載開發包,打開http://people.apache.org/builds/struts/會看到相應的版本,當前最新版本爲2.1.2下載struts-2.1.2-all.zip 包含了源代碼和文檔說明。(Struts2需要1.5的JDK)

下面的表說明了各個包的作用

壓縮包名稱 作用
struts-2.1.0-docs.zip 文檔,包含了Struts2API
struts-2.1.0-lib.zip 構建Struts2工程所需要的包
struts-2.1.0-src.zip Struts2的所有源代碼
struts2-blank-2.1.0.war 空白工程
struts-2.1.0-all.zip 包括上面所有的內容

從網站上下載的Struts2包含了二三十個庫文件,但大多數是可選的,有些庫是插件,用於和其他框架的整合。

讀者可自行下載struts2-blank-2.1.2.war壓縮包,展開後是一個非常簡單的項目,從WEB-INF/lib目錄中可以看到5個庫文件,解釋如下:

包名 說明
commons-logging-1.0.4.jar 日誌管理
freemarker-2.3.8.jar 表現層框架,定義了struts2的可視組件主題(theme)
ognl-2.6.11.jar OGNL表達式語言,struts2支持該EL
struts2-core-2.1.1.jar struts2的核心庫
xwork-2.0.4.jar webwork的核心庫,自然需要它的支持

筆者使用的是eclipse進行開發,新建web項目 在lib中把以上5個包拷貝進去,現在開始我們的第一個struts2的程序Hello World吧

首先在web.xml中添加以下代碼:

<display-name>Struts 2.0 Hello World</display-name>
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
</welcome-file-list>

將Struts2所帶的過濾器org.apache.struts2.dispatcher.FilterDispatcher配置到工程的web.xml文件中

默認情況下,該過濾器攔截請求字符串中以.action結尾的請求,並將該請求委託給指定的Action進行處理。

第二步創建Action類,這個類可以不繼承任何類 但爲了方便在這裏我們繼承了ActionSupport 覆蓋 execute()方法來做些事情

public String execute() throws Exception {

System.out.println(”世界,您好”);

return SUCCESS;

}

在這裏大家注意到了 引用了靜態變量SUCCESS 這是Action 所提供的,ActionSupport 是繼承了Action,此外還有幾個變量,我們察看源代碼:

com.opensymphony.xwork2. ActionSupport類所實現的接口

public class ActionSupport implements Action, Validateable, ValidationAware, TextProvider, LocaleProvider, Serializable {

}

com.opensymphony.xwork2.Action接口

public interface Action {

public static final String SUCCESS = “success”; 表示請求處理成功

public static final String NONE = “none”; 表示請求處理完成後不跳轉到任何頁面

public static final String ERROR = “error”; 表示請求處理失敗

public static final String INPUT = “input”; 表示輸入時如果驗證失敗應該跳轉到什麼地方

public static final String LOGIN = “login”; 表示登陸失敗後跳轉的目標

public String execute() throws Exception;

}

第三步:在工程類路徑下創建struts.xml文件,這是Struts2的配置文件,類似於Struts1.x中的struts-config.xml,在struts.xml文件中可以配置Action、Bean、Interceptor等組件

<struts>

<include file=”struts-default.xml”></include>

<package name=”a” extends=”struts-default”>

<action name=”helloworld” class=”com.lizanhong.action.HelloWorldAction”>

<result>/result.jsp</result>

</action>

</package>

</struts>

對以上出現的一些標籤簡單的解釋

標籤名稱 說明
include 包含其他xml文件,在示例中,這意味着struts.xml可以訪問定義在struts-default.xml文件中的組件。該元素可以使得Struts2定義多個配置文件,”分而治之”。

要注意的是,任何一個struts2配置文件都應該和struts.xml有相同的格式,包括doctype,並且可以放在類路徑下的任何地方。

package 爲Action或截攔器分組。name:名稱,必填項,名稱自定義,沒特別要求。方便別的package引用。

extends:package能繼承其他的package,即通過該屬性實現,值爲另一個package的name。

在示例中,extends =”struts-default”是從struts-default.xml中繼承的。

action 定義Action,name屬性爲訪問時用到的名稱,class屬性是Action的類名。
result 根據Action的返回值定義頁面導航。Action的預定義的返回值有:

String SUCCESS = “success”;

String NONE = “none”;

String ERROR = “error”;

String INPUT = “input”;

String LOGIN = “login”;

比如,當Action返回SUCCESS時希望轉到ok.jsp頁面,則可以這樣寫:

<result name=”success”>ok.jsp</result>

其中,name的缺省爲success。


發佈工程,在瀏覽器中輸入:http://localhost:8081/HelloStruts2/helloworld.action

控制檯就會出現”世界,您好” 這樣我們的第一個簡單的struts2程序就完成了
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章