20160427Struts2--入門1

破玉發表於2016-04-27

參考資料來自傳智播客:非原創,只是做個筆記:

 

一、Struts2簡介:

Struts2是在WebWork2基礎發展而來的。和struts1一樣, Struts2也屬於MVC框架。不過有一點大家需要注意的是:儘管Struts2和struts1在名字上的差別不是很大,但Struts2和struts1在程式碼編寫風格上幾乎是不一樣的。那麼既然有了struts1,為何還要推出struts2。主要是因為struts2有以下優點:
 
  1 > 在軟體設計上Struts2沒有像struts1那樣跟Servlet API和struts API有著緊密的耦合,Struts2的應用可以不依賴於Servlet API和struts API。 Struts2的這種設計屬於無侵入式設計,而Struts1卻屬於侵入式設計。
public class OrderListAction extends Action {
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
}
}
  2> Struts2提供了攔截器,利用攔截器可以進行AOP程式設計,實現如許可權攔截等功能。
  3> Strut2提供了型別轉換器,我們可以把特殊的請求引數轉換成需要的型別。在Struts1中,如果我們要實現同樣的功能,就必須向Struts1的底層實現BeanUtil註冊型別轉換器才行。
 4> Struts2提供支援多種表現層技術,如:JSP、freeMarker、Velocity等
 5> Struts2的輸入校驗可以對指定方法進行校驗,解決了Struts1長久之痛。
 6> 提供了全域性範圍、包範圍和Action範圍的國際化資原始檔管理實現
 

二、Struts2配置

 

搭建Struts2環境時,我們一般需要做以下幾個步驟的工作:
1》找到開發Struts2應用需要使用到的jar檔案.
2》編寫Struts2的配置檔案
3》在web.xml中加入Struts2 MVC框架啟動配置
 
大家可以到http://struts.apache.org/download.cgi#struts2014下載struts-2.x.x-all.zip,下載完後解壓檔案,開發struts2應用需要依賴的jar檔案在解壓目錄的lib資料夾下。不同的應用需要的JAR包是不同的。下面給出了開發Struts 2程式最少需要的JAR。
struts2-core-2.x.x.jar :Struts 2框架的核心類庫
xwork-core-2.x.x.jar :XWork類庫,Struts 2在其上構建
ognl-2.6.x.jar :物件圖導航語言(Object Graph Navigation Language),struts2框架通過其讀寫物件的屬性
freemarker-2.3.x.jar :Struts 2的UI標籤的模板使用FreeMarker編寫
commons-logging-1.x.x.jar :ASF出品的日誌包,Struts 2框架使用這個日誌包來支援Log4J和JDK 1.4+的日誌記錄。
commons-fileupload-1.2.1.jar 檔案上傳元件,2.1.6版本後必須加入此檔案
 
Struts2預設的配置檔案為struts.xml ,該檔案需要存放在WEB-INF/classes下,該檔案的配置模版如下:
<?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>
</struts>
在struts1.x中, struts框架是通過Servlet啟動的。在struts2中,struts框架是通過Filter啟動的。他在web.xml中的配置如下:
 
<filter>
    <filter-name>struts2</filter-name>
    <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
 <!-- 自從Struts 2.1.3以後,下面的FilterDispatcher已經標註為過時
    <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class> --> 
</filter>
<filter-mapping>
    <filter-name>struts2</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>
在StrutsPrepareAndExecuteFilter的init()方法中將會讀取類路徑下預設的配置檔案struts.xml完成初始化操作。
 
注意:struts2讀取到struts.xml的內容後,以javabean形式存放在記憶體中,以後struts2對使用者的每次請求處理將使用記憶體中的資料,而不是每次都讀取struts.xml檔案
 
 三、第一個struts2應用
第一個Struts2應用--HelloWorld
在預設的配置檔案struts.xml 中加入如下配置
<?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>
   <package name="itcast" namespace="/test" extends="struts-default">
        <action name="helloworld" class="cn.itcast.action.HelloWorldAction" method="execute" >
    <result name="success">/WEB-INF/page/hello.jsp</result>
        </action>
    </package> 
</struts>

 

<package name="itcast" namespace="/test" extends="struts-default">
    <action name="helloworld" class="cn.itcast.action.HelloWorldAction" method="execute" >
        <result name="success">/WEB-INF/page/hello.jsp</result>
    </action>
 </package> 

 

在struts2框架中使用包來管理Action,包的作用和java中的類包是非常類似的,它主要用於管理一組業務功能相關的action。在實際應用中,我們應該把一組業務功能相關的Action放在同一個包下。
 
配置包時必須指定name屬性,該name屬性值可以任意取名,但必須唯一,他不對應java的類包,如果其他包要繼承該包,必須通過該屬性進行引用。包的namespace屬性用於定義該包的名稱空間,名稱空間作為訪問該包下Action的路徑的一部分,如訪問上面例子的Action,訪問路徑為:/test/helloworld.action。 namespace屬性可以不配置,對本例而言,如果不指定該屬性,預設的名稱空間為“”(空字串)。
 
通常每個包都應該繼承struts-default包, 因為Struts2很多核心的功能都是攔截器來實現。
如:從請求中把請求引數封裝到action、檔案上傳和資料驗證等等都是通過攔截器實現的。 struts-default定義了這些攔截器和Result型別。可以這麼說:當包繼承了struts-default才能使用struts2提供的核心功能。 struts-default包是在struts2-core-2.x.x.jar檔案中的struts-default.xml中定義。 struts-default.xml也是Struts2預設配置檔案。 Struts2每次都會自動載入 struts-default.xml檔案。
 
包還可以通過abstract=“true”定義為抽象包,抽象包中不能包含action
 
 程式碼:
package com.dzq.action;

public class HelloWorldAction {
    private String msg;
    
    
    public String getMessage() {
        return msg;
    }


    public String execute(){
        msg="Hello World!!!";
        return "success";
    }
}

 

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
${message }
</body>
</html>

 

 
 
在struts1中,通過<action path=“/test/helloworld”>節點的path屬性指定訪問該action的URL路徑。在struts2中,情況就不是這樣了,訪問struts2中action的URL路徑由兩部份組成:包的名稱空間+action的名稱,例如訪問本例子HelloWorldAction的URL路徑為:/test/helloworld (注意:完整路徑為:http://localhost:埠/內容路徑/test/helloworld)。另外我們也可以加上.action字尾訪問此Action。
 
 
<package name="itcast" namespace="/test" extends="struts-default">
        <action name="helloworld" class="cn.itcast.action.HelloWorldAction" method="execute" >
    <result name="success">/WEB-INF/page/hello.jsp</result>
        </action>
 </package>