明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

用WebWork、JSP、Velocity創(chuàng)建注冊(cè)頁面

[摘要]WebWork是一個(gè)源代碼開放的Web應(yīng)用框架,用于簡(jiǎn)化基于Web的應(yīng)用開發(fā)。本專欄介紹了WebWork并且描述了如何使用WebWork和JavaServer Pages(JSP)、Velocity兩種技術(shù)來建立注冊(cè)界面的過程。Web 應(yīng)用程序的設(shè)計(jì)開發(fā)是復(fù)雜并且費(fèi)時(shí)的。然而,你能夠通過運(yùn)用一種框...

WebWork是一個(gè)源代碼開放的Web應(yīng)用框架,用于簡(jiǎn)化基于Web的應(yīng)用開發(fā)。本專欄介紹了WebWork并且描述了如何使用WebWork和JavaServer Pages(JSP)、Velocity兩種技術(shù)來建立注冊(cè)界面的過程。

Web 應(yīng)用程序的設(shè)計(jì)開發(fā)是復(fù)雜并且費(fèi)時(shí)的。然而,你能夠通過運(yùn)用一種框架處理常見的Web應(yīng)用程序來簡(jiǎn)化開發(fā)流程。許多開源Web應(yīng)用框架能夠做到這一點(diǎn)甚至更好一些。這些開發(fā)框架中最好的一個(gè)就是WebWork,是開源項(xiàng)目中OpenSymphony組的一個(gè)Web應(yīng)用開發(fā)框架。

 WebWork的最大優(yōu)點(diǎn)是它的簡(jiǎn)單性和靈活性。WebWork有一個(gè)很小的API,它使開發(fā)者可以迅速進(jìn)行開發(fā)工作。WebWork是許多特性和適用性的組合,包括使用variour view技術(shù),例如JavaServer Pages(JSP),Velocity,Extensible Stylesheet Language Transformations 
Specification(XSLT)和JasperReporters。WebWork擁有一個(gè)活躍的社區(qū),有許多文章、開發(fā)者和用戶。

注意:本文基于WebWork1.3.0 release candidate 2(RC2)。為了使用本文提供的例子,你需要在你的應(yīng)用服務(wù)器的webapps目錄下建立文件夾,將例子拷貝至新的文件夾下,同時(shí)將所需的jar文件從WebWork distribution拷貝至WEB-INF/lib目錄。在此處下載WebWork和本文相關(guān)的源代碼。

------
Actions

 WebWork的一個(gè)最重要的特色就是Action接口。WebWork actions通過在頁面(視圖)和商業(yè)邏輯間提供mapping來控制Web應(yīng)用程序流程。在WebWork中,提交窗體到一個(gè)action URI(Uniform Resource Identifier);這個(gè)URI指向一個(gè)相應(yīng)的action;action執(zhí)行;用戶可以前進(jìn)到相應(yīng)的視圖。

下述class,LoginAction,是WebWork處理基于Web應(yīng)用的注冊(cè)窗體的例子。LoginAction擴(kuò)展了ActionSupport。它是一個(gè)基類,提供了處理錯(cuò)誤、視圖映射、和許多有用的功能。





import webwork.action.*;

public class LoginAction extends ActionSupport
{
  private String userName;
  private String password; 

  public String getPassword()
  {
    return password;
  }

  public String getUserName()
  {
    return userName;
  }

  public void setPassword(String password)
  {
    this.password = password;
  }

  public void setUserName(String userName)
  {
    this.userName = userName;
  }

  public String doExecute()
  {
    return SUCCESS;
  }

  public void doValidation()
  {
    if (userName == null 
 userName.length() < 1) addError("UserName", "Please enter username.");
    if (password == null 
 password.length() < 1) addError("Password", "Please enter password.");
  }
}

LoginAction包括了兩個(gè)JavaBean屬性,password和username。WebWork把數(shù)據(jù)從屬性中放置到你的視圖中并且自動(dòng)解析送到action的參數(shù)來設(shè)置屬性值。

 LoginAction重載了ActionSupport的兩個(gè)方法:doValidation()和doExecute()。doValidation()方法驗(yàn)證參數(shù),doExecute()方法讓用戶前進(jìn)到相應(yīng)的視圖。doExecute()方法返回一個(gè)字符串,如果所有的處理是成功的,返回常量success。如果有任何問題發(fā)生,在用戶輸入視圖上返回常量input。在LoginAction的doValidation()方法中調(diào)用addError指出了一個(gè)認(rèn)證問題并且讓用戶返回INPUT視圖。

---------

View mapping
 
WebWork有兩種方法從map到視圖:通過一個(gè)Action.xml文件或者一個(gè)views.properties文件。每一種動(dòng)作應(yīng)該具有一個(gè)INPUT視圖和一個(gè)SUCCESS視圖。下述Action.xml文件定義了兩個(gè)actions,loginJSP和loginVelocity。這兩個(gè)action都使用了LoginAction類。如果LoginAction返回SUCCESS,這兩個(gè)action使用LoginAction類并且使用戶轉(zhuǎn)向success.html。如果LoginAction返回INPUT,action轉(zhuǎn)向相應(yīng)的INPUT視圖,或者login.jsp、或者login.vm;






<actions>

  <action name="LoginAction" alias="loginJSP">
    <view name="input">login.jsp</view>
    <view name="success">success.html</view>
  </action>

  <action name="LoginAction" alias="loginVelocity">
    <view name="input">login.vm</view>
    <view name="success">success.html</view>
  </action>

</actions> --------
視圖

盡管WebWork對(duì)于許多不同的視圖技術(shù)提供了支持,但是最為常見的是JSP和Velociy。以下頁面是兩個(gè)注冊(cè)頁面的例子--一個(gè)使用了JSP另一個(gè)使用了Velocity。每個(gè)頁面都包括了一個(gè)用戶部分和一個(gè)密碼部分,這兩部分提交給WebWork action。

Login.jsp頁面通過使用WebWork標(biāo)記庫來建立和處理以上兩個(gè)部分,并且通過錯(cuò)誤收集器來處理錯(cuò)誤。webwork:textfield 和 webwork:password標(biāo)記建立了text和password部分,webwork:iterator標(biāo)記處理從LoginAction返回的錯(cuò)誤。 webwork:property標(biāo)記設(shè)置username,password和errors屬性。






<%@ taglib uri="webwork" prefix="webwork" %>

<html>

  <head>
    <title>WebWork JSP Example</title>
  </head>

  <body>

  <form action="loginJSP.action" method="post">

    <webwork:property>
      <webwork:textfield label="'Name'" name="'userName'"/>
      <webwork:password label="'Password'" name="'password'"/>
    </webwork:property>

    <input type="submit" value="Submit"/>
  </form>

  <webwork:iterator value="errors">
    <br><webwork:property/>
  </webwork:iterator>

  </body>
</html>


    login.vm頁面使用了Velocity模板語言來建立域并且處理錯(cuò)誤。在Velocity中,$符號(hào)表明了一個(gè)參考。!符號(hào)告訴Velocity如果參考為空,那么什么都不顯示。#符號(hào)表示了一個(gè)指令。在下述例子中,$!userName和$!password表明參考引用了LoginAction中的username和password;#foreach在錯(cuò)誤處理屬性中指示了循環(huán)。





<html>

  <head>
    <title>WebWork Velocity Example</title>
  </head>

  <body>

  <form action="loginVelocity.action" method="post">
    <input type="text" name="userName" value="$!userName"/>
    <input type="text" name="password" value="$!password"/>
    <input type="submit" value="Submit"/>
  </form>

  #foreach ($error in $errors)
<br>$error
  #end

  </body>

</html>



---------------
開始工作!
   
WebWork是一個(gè)易用的、靈活的、功能強(qiáng)大的開源Web應(yīng)用框架,本文介紹了它的基本功能。訪問OpenSympony的網(wǎng)站去學(xué)習(xí)并且下載最新版本的WebWork。你下載完WebWork后,到Jakarta的網(wǎng)站的上部去尋找Velocity,一種簡(jiǎn)單、快速的開源引擎,它是你在網(wǎng)頁中使用JSP的另一個(gè)選擇。
-----------------
作者介紹

Erik Swenson 是Open Source Software Solutions的顧問和建立者。他主要研究使用開源軟件和組件來進(jìn)行java開發(fā)。此外,他參與開發(fā)了開源項(xiàng)目JasperEdit和OpenReports。
------------------
資源

下載本文相關(guān)的源代碼
http://www.javaworld.com/javaworld/jw-03-2003/opensource/jw-0307-opensourceprofile.zip

從OpenSymphony網(wǎng)站下載WebWork: 
http://www.opensymphony.com/webwork/

Velocity 是Apache Jakarta項(xiàng)目的一部分,從以下地址下載: 
http://jakarta.apache.org/velocity/index.html

“使用Velocity模板引擎” Geir Magnusson Jr. (JavaWorld,  2001年12月): 
http://www.javaworld.com/javaworld/jw-12-2001/jw-1228-velocity.html

其他開源Web應(yīng)用框架包括: 

Maverick:
http://mav.sourceforge.net/ 
Struts:
http://jakarta.apache.org/struts/index.html
JasperReports homepage: 
http://jasperreports.sourceforge.net/

Matrix經(jīng)javaworld授權(quán)翻譯.加入matrix,與java共舞: www.matrix.org.cn(出處:PConline)