posts - 495,  comments - 11,  trackbacks - 0

          struts2.0簡單的例子

          今天在apache網站上無意中看到了struts項目2.0.1正式發布了,懷著欣喜的心情我下載了stuts2.0.1完整包。 Struts2.0.1是struts項目和WebWork2.2項目的合并版本,集成了兩大流行MVC框架的優點,對struts框架來說是一個大的提升,同時也更大程度地簡化了開發人員的開發過程。我簡單地研究了一下這個新版本,現在給大家介紹一個入門級的小例子,希望能對學習這個新版本的朋友有點幫助。
          這個例子完成了一次URL調用返回結果頁面的過程。
          首先,要從apache網站上下載struts2.0.1的完整包(可以從這里下載:http://struts.apache.org/downloads.html),解壓后需要找到下列幾個文件:
          commons-logging-1.0.4.jar
          freemarker-2.3.4.jar
          ognl-2.6.7.jar
          struts2-api-2.0.1.jar
          struts2-core-2.0.1.jar
          xwork-2.0-beta-1.jar
          然后,我們就開始做第一個例子,我們就使用經典的“HelloWorld”的名字吧!
          1. 制作目錄結構
          如下圖所示:
          stuts2是web應用的根目錄。
          2. 拷貝引用文件
          將上面列舉的jar文件拷貝到步驟1中制作的目錄struts2\WEB-INF\lib中。
          3. 制作jsp文件HelloWorld.jsp

          <%@ taglib prefix="s" uri="/struts-tags" %>
          <html>
          <head>
          <title>Hello World!</title>
          </head>
          <body>
          <h2><s:property value="message" /></h2>
          </body>
          </html>

          將該文件拷貝到步驟1中制作的目錄struts2\example中。
          4.制作java文件HelloWorld.java

          package example;

          /** *//**
          * <code>Set welcome message.</code>
          */

          import com.opensymphony.xwork2.ActionSupport;
          public class HelloWorld extends ActionSupport ...{

          public static final String MESSAGE = "Struts is up and running ...";

          public String execute() throws Exception ...{
          setMessage(MESSAGE);
          return SUCCESS;
          }


          private String message;

          public void setMessage(String message)...{
          this.message = message;
          }


          public String getMessage() ...{
          return message;
          }

          }

          使用下面的命令編譯這個java文件:
          set CLASSPATH=yourdirectory\xwork-2.0-beta-1.jar
          javac HelloWorld.java
          將編譯后的HelloWorld.class文件拷貝到步驟1中制作的目錄struts2\WEB-INF\classes\example中。
          5.制作web應用的描述文件web.xml

          <?xml version="1.0" encoding="UTF-8"?>
          <web-app xmlns="http://java.sun.com/xml/ns/j2ee"
          ?????? xmlns:xsi
          ="http://www.w3.org/2001/XMLSchema-instance"
          ?????? xsi:schemaLocation
          ="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
          ?????? version
          ="2.4">

          <display-name>Struts Blank</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>
          </web-app>

          將該文件拷貝到步驟1中制作的目錄struts2\WEB-INF中。
          6.制作MANIFEST.MF文件(從其它地方隨便找一個即可)
          將該文件拷貝到步驟1中制作的目錄struts2\META-INF中。
          7.制作struts配置文件struts.xml和struts.properties
          struts.xml文件:

          <!DOCTYPE struts PUBLIC
          "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
          "http://struts.apache.org/dtds/struts-2.0.dtd"
          >
          <struts>
          <package name="abc" namespace="/example" extends="struts-default">
          <action name="HelloWorld" class="example.HelloWorld">
          <result>/example/HelloWorld.jsp</result>
          </action>
          <!-- Add your actions here -->
          </package>
          </struts>

          struts.properties文件:
          struts.devMode = true
          struts.enable.DynamicMethodInvocation = false
          將這兩個文件拷貝到步驟1中制作的目錄struts2\ WEB-INF\classes中。
          好了整個例子的文件我們都搞定了。
          最后,你可以將制作好的web應用struts2拷貝到tomcat下運行。
          訪問http://localhost:8080/struts2/example/HelloWorld.action如果能夠看到頁面上的“Struts is up and running ...”提示信息說明你的例子是正確的。

          Struts2與Struts1的對比

          (轉自:javaeye)

          Action 類:
          ? Struts1要求Action類繼承一個抽象基類。Struts1的一個普遍問題是使用抽象類編程而不是接口。
          ? Struts 2 Action類可以實現一個Action接口,也可實現其他接口,使可選和定制的服務成為可能。Struts2提供一個ActionSupport基類去實現 常用的接口。Action接口不是必須的,任何有execute標識的POJO對象都可以用作Struts2的Action對象。

          線程模式:
          ? Struts1 Action是單例模式并且必須是線程安全的,因為僅有Action的一個實例來處理所有的請求。單例策略限制了Struts1 Action能作的事,并且要在開發時特別小心。Action資源必須是線程安全的或同步的。
          ? Struts2 Action對象為每一個請求產生一個實例,因此沒有線程安全問題。(實際上,servlet容器給每個請求產生許多可丟棄的對象,并且不會導致性能和垃圾回收問題)

          Servlet 依賴:
          ? Struts1 Action 依賴于Servlet API ,因為當一個Action被調用時HttpServletRequest 和 HttpServletResponse 被傳遞給execute方法。
          ? Struts 2 Action不依賴于容器,允許Action脫離容器單獨被測試。如果需要,Struts2 Action仍然可以訪問初始的request和response。但是,其他的元素減少或者消除了直接訪問HttpServetRequest 和 HttpServletResponse的必要性。

          可測性:
          ? 測試Struts1 Action的一個主要問題是execute方法暴露了servlet API(這使得測試要依賴于容器)。一個第三方擴展--Struts TestCase--提供了一套Struts1的模擬對象(來進行測試)。
          ? Struts 2 Action可以通過初始化、設置屬性、調用方法來測試,“依賴注入”支持也使測試更容易。

          捕獲輸入:
          ? Struts1 使用ActionForm對象捕獲輸入。所有的ActionForm必須繼承一個基類。因為其他JavaBean不能用作ActionForm,開發者經常創建多余的類捕獲輸入。動態Bean(DynaBeans)可以作為創建傳統ActionForm的選擇,但是,開發者可能是在重新描述(創建)已經存在的JavaBean(仍然會導致有冗余的javabean)。
          ? Struts 2直接使用Action屬性作為輸入屬性,消除了對第二個輸入對象的需求。輸入屬性可能是有自己(子)屬性的rich對象類型。Action屬性能夠通過 web頁面上的taglibs訪問。Struts2也支持ActionForm模式。rich對象類型,包括業務對象,能夠用作輸入/輸出對象。這種 ModelDriven 特性簡化了taglib對POJO輸入對象的引用。

          表達式語言:
          ? Struts1 整合了JSTL,因此使用JSTL EL。這種EL有基本對象圖遍歷,但是對集合和索引屬性的支持很弱。
          ? Struts2可以使用JSTL,但是也支持一個更強大和靈活的表達式語言--"Object Graph Notation Language" (OGNL).

          綁定值到頁面(view):
          ? Struts 1使用標準JSP機制把對象綁定到頁面中來訪問。
          ? Struts 2 使用 "ValueStack"技術,使taglib能夠訪問值而不需要把你的頁面(view)和對象綁定起來。ValueStack策略允許通過一系列名稱相同但類型不同的屬性重用頁面(view)。
           
          類型轉換:
          ? Struts 1 ActionForm 屬性通常都是String類型。Struts1使用Commons-Beanutils進行類型轉換。每個類一個轉換器,對每一個實例來說是不可配置的。
          ? Struts2 使用OGNL進行類型轉換。提供基本和常用對象的轉換器。

          校驗:
          ? Struts 1支持在ActionForm的validate方法中手動校驗,或者通過Commons Validator的擴展來校驗。同一個類可以有不同的校驗內容,但不能校驗子對象。
          ? Struts2支持通過validate方法和XWork校驗框架來進行校驗。XWork校驗框架使用為屬性類類型定義的校驗和內容校驗,來支持chain校驗子屬性

          本文轉自:http://blog.csdn.net/paulsen1980/archive/2007/05/18/1614643.aspx

          posted on 2007-08-13 02:29 jadmin 閱讀(65) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 抚顺市| 临邑县| 宿松县| 平阳县| 栖霞市| 乌审旗| 岳阳市| 南华县| 丹阳市| 云和县| 阳朔县| 甘洛县| 且末县| 全椒县| 武鸣县| 大理市| 桂东县| 高唐县| 鞍山市| 保定市| 离岛区| 盈江县| 新丰县| 东乡县| 杭州市| 衡东县| 平顺县| 泸州市| 惠安县| 吕梁市| 绿春县| 丰城市| 佛教| 阆中市| 本溪市| 桑植县| 东丰县| 博客| 上杭县| 库车县| 泸州市|