說明:本文經過筆者對struts2.0.8自帶的實例struts2-blank-2.0.8學習而寫,對該例子進行了部分修改,希望對廣大象要學習struts2的朋友有所幫助。
一. 實例說明
本例是Struts2的簡單實例,通過本工程的學習,我們將會對struts2的表單以及表單驗證有一個初步的認識、了解struts2的配置以及初探Struts2的本地化輸出。
二. 編碼準備
1. 包的引入
在MyEclipse或NetBeans中建立web工程,將所需的包放入WebRoot/lib目錄中,本實例所需的包有:
commons-logging-1.1.jar
freemarker-2.3.8.jar
ognl-2.6.11.jar
struts2-core-2.0.8.jar
xwork-2.0.3.jar
這些包在struts-2.0.8-all\struts-2.0.8\lib目錄下都可以找到,請讀者自行下載。
2. web.xml的配置
要使struts能正常工作,需修改web.xml的內容,為其增加struts2的FilterDispatcher,修改后的web.xml的內容如下:
3. 建立源碼目錄和jsp存放目錄
在src目錄下建立example文件夾,用于存放本實例的java文件等。在WebRoot文件夾下建立子文件夾example,用于存放本工程的jsp文件。
三. 編碼
1. Welcome.jsp和Login.jsp的編寫
在該頁面的頂部,我們需要將struts2的標簽庫引入,語句為:<%@ taglib prefix="s" uri="/struts-tags" %>
在該頁面,主要用到struts2的<s:url>標簽,該頁面主要用到該標簽的兩個屬性,分別為value和action,其中action屬性表示用action來產生url,而value表示使用的目標值。在頁面上點擊“查看源文件”按鈕,可看到生成的語句分別變為:
<link href="/struts2-blank-2.0.8/css/examplecss" rel="stylesheet" type="text/css"/>
<a href="/struts2-blank-2.0.8/example/Login.jsp ">
<a href="/struts2-blank-2.0.8/example/Register.action">
由此可知使用該標簽時,struts2會自動為我們帶上下文路徑,對于加了屬性action的<s:url>標簽,后面會自動帶上“.action”作為后綴。
點擊“登錄”鏈接后,跳轉到Login.jsp頁面,該頁包含一個登錄表單,讓用戶輸入用戶名和密碼信息,用戶點擊提交按鈕,跳轉到指定的Action——Login進行處理。Login.jsp的內容如下:
該頁用到Struts2的表單標簽<s:form>、<s:textfield>和<s:password>。
<s:form>的action屬性表示表單提交后跳轉的action的名稱,此處為Login,該標簽最終將生成HTML的form;
<s:textfield>標簽類同于HTML的<input type=”text” …>,其中name表示屬性域的名稱,label表示其前的提示名;
<s:password>標簽類同于HTML的<input type=”password” …>,其name和label類同于<s:textfield>,在此略。
2. 配置文件struts.xml和example.xml
可看到該文件通過<include file="example.xml"/>將example.xml也作為struts2的配置文件。
接下來,讓我們看看example.xml的配置:
3. Login和ExampleSupport類以及驗證配置類Login-validation.xml的編寫
在配置文件example.xml中,定義了兩個Action,下面我們用代碼來實現這兩個Action
首先讓我們來看看ExampleSupport這個Action,這個Action不做任何操作,集成自ActionSupport,是本工程的各Action類的基類,該類的代碼如下:
接著讓我們來看看Login這個Action,該類繼承自ExampleSupport類,該Action需實現的業務邏輯如下:
1) 當用戶名(username)或密碼(password)有一者或兩者為空時,登錄不成功,跳轉到登錄信息輸入頁面;
2) 當用戶名(username)和密碼(password)都不為空時,登錄成功,跳轉到主菜單頁。
當工程變得愈發復雜時,這一小段一小段驗證代碼將會變得難以維護,出于此原因,我們可以考慮采用struts2提供的驗證機制來實現。在src目錄下建立實現驗證的xml文件Login-validation.xml,為Login Action中的username和password屬性增加非空驗證,驗證配置如下:
當驗證未通過時,將不會進入Login Action中的execute方法,此時可刪除掉Login這個Action中的驗證內容,該類的execute方法直接跳轉到SUCCESS即可,修改后的代碼略。
4. 本地化輸出——資源文件package.properties
為了本地化的輸出驗證錯誤信息,我們可以將參數信息和錯誤信息放入資源文件中,資源文件package.properties位于src/example目錄下,內容如下:
requiredstring = ${getText(fieldName)}不能為空.
password = 密碼
username = 用戶名
Missing.message = 該部分尚未構建,請稍候訪問...
在src/example目下下建立對應的中文資源文件package_zh_CN.properties,為了避免中文亂碼問題,我們編寫一個批處理文件code.bat來對package.properties進行編碼處理,主要用到native2ascii命令,其內容如下:
del package_zh_CN.properties
copy package.properties package_zh_CN.properties.gbk
native2ascii -encoding GBK package_zh_CN.properties.gbk package_zh_CN.properties
del package_zh_CN.properties.gbk
del *.bak
運行該批處理文件,可在package_zh_CN.properties中可看到編碼后的資源文件信息,如下:
requiredstring = ${getText(fieldName)}\u4e0d\u80fd\u4e3a\u7a7a.
password = \u5bc6\u7801
username = \u7528\u6237\u540d
Missing.message = \u8be5\u90e8\u5206\u5c1a\u672a\u6784\u5efa\uff0c\u8bf7\u7a0d\u5019\u8bbf\u95ee...
5. Register.jsp和Missing.jsp的編寫
在2中的example.xml中,我們配置了通配符映射,在Welcome.jsp中,我們使用
<a href="<s:url action="Register"/>">注冊</a>
該頁面包含Missing.jsp頁面,其代碼如下:
四.總結
到此為止,我們的實例已構建完,可通過瀏覽器訪問:http://localhost:8080/struts2-blank-2.0.8/example/Welcome.jsp看到我們的勞動成果。下面總結一下我們在該實例中學到的東西。
1. 常用的一些標簽的使用
在本實例中,我們學習了<s:textfield>、<s:password>、<s:form>以及<s:url>的使用。
2. 表單數據的驗證
本文描述了一個簡單的表單的數據非空驗證。
3. 本地化輸出錯誤提示信息
在驗證失敗時,用資源文件來輸出錯誤提示信息。
4.Strut2配置文件中通配符的使用
對于某些地址,我們可以使用在struts2的配置通配符來使其映射到某個Action中去。
下一篇:實例篇:struts2-mailreader-2.0.8實例學習
上一篇:基礎篇:本地化輸出