用WebWork、JSP、Velocity創(chuàng)建注冊(cè)頁面
發(fā)表時(shí)間:2024-01-22 來源:明輝站整理相關(guān)軟件相關(guā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)用一種框...
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)