[Sturts2]繼承ActionSupport類
上篇部落格中我們介紹了Sturts2框架的搭建,今天我們在此基礎上來繼承ActionSupport類。
工具:MyEclipse
1. 首先我們在com.hnpi.action包下名字為HelloWorldAction的class檔案
(注意需要繼承ActionSupport類)
package com.hnpi.action;
import com.opensymphony.xwork2.ActionSupport;
public class HelloWorldAction extends ActionSupport {
}
ActionSupport類本身實現了Action介面,所以繼承ActionSupport類就相當於實現了Action介面。除此之外,ActionSupport類還實現了其它幾個介面,來為程式設計師提供更多使用的功能,這些介面和Struts2的一些其他特性相結合,可以實現基本的資料驗證功能和國際化。介面如下所示:
com.opensymphony.xwork2.Validateable; //提供validate()方法來為Action增加驗證的功能
com.opensymphony.xwork2.Validateaware; //提供方法來儲存和恢復action或field級的錯誤資訊
com.opensymphony.xwork2.TextProvider; //提供獲取本地資訊文字的功能
com.opensymphony.xwork2.LocaleProvider;//提供getLocale()方法來獲取本地訊息
**2.接下來需要在Action類中覆蓋實現validate方法來對傳輸過來的資料進項校驗。
**
程式碼如下:
package com.hnpi.action; import com.opensymphony.xwork2.ActionSupport; public class HelloWorldAction extends ActionSupport { private String account; private String password; private String submitFlag; public String execute() throws Exception { this.businessExecute(); return "toWelcome"; } public void validate(){ if(account==null || account.trim().length()==0){ this.addFieldError("account", "賬號不可以為空"); } if(password==null || password.trim().length()==0){ this.addFieldError("password", "密碼不可以為空"); } if(password!=null && !"".equals(password.trim()) && password.trim().length()<6){ this.addFieldError("password", "密碼長度至少為6位"); } } /** * 示例方法,表示可以執行業務邏輯處理的方法, */ public void businessExecute(){ System.out.println("使用者輸入的引數為==="+"account="+account+",password="+password+",submitFlag="+submitFlag); } public String getAccount() { return account; } public void setAccount(String account) { this.account = account; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public String getSubmitFlag() { return submitFlag; } public void setSubmitFlag(String submitFlag) { this.submitFlag = submitFlag; } }
從上面的示例可以看出,在validate方法中,可以對使用者請求中傳遞過來的資料進行驗證,同一個資料可以進行多方面的驗證。
如果驗證結果是資料不正確,那麼就使用父類提供的addFieldError方法來新增驗證的錯誤訊息。addFieldError方法有兩個引數,前面的是訊息的key值,後面是具體的訊息。
3. 建立兩個jsp頁面;來將錯誤資訊顯示在前臺頁面上,程式碼如下:
login.jsp
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@ taglib prefix="s" uri="/struts-tags"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; utf-8">
<title>登入頁面</title>
<style type="text/css">
ul,li {
list-style-type:none;
margin:0px;
float:left;
}
</style>
</head>
<body>
<form action="helloworld" method="post">
<input type="hidden" name="submitFlag" value="login"/>
<div>
<font color=red><s:fielderror fieldName="account"/></font>
<br/>
賬號:<input type="text" name="account">
</div>
<div>
<font color=red><s:fielderror fieldName="password"/></font>
<br/>
密碼:<input type="password" name="password">
</div>
<input type="submit" value="提交">
</form>
</body>
</html>
welcome.jsp來告訴使用者登入成功
<%@ page language="java" import="java.util.*" pageEncoding="gbk"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>錄入頁面</title>
</head>
<body>
登陸成功 <br>
</body>
</html>
在JSP頁面中利用<s:fielderror/>標籤在相應的欄位處輸出錯誤資訊。但是,在實際開發中,<s:fielderror/>它會輸出全部的錯誤資訊內容。而如果想選擇性地輸出指定錯誤資訊。我們可以使用如下程式碼解決:
<!-- 方法一 -->
<s:fielderror>
<s:param>username</s:param> <!--顯示指定的 username欄位的 錯誤訊息-->
<s:fielderror/>
<!-- 方法二 -->
<s:fielderror fieldName="username"/> <!--顯示指定的 username欄位的 錯誤訊息-->
4. 需要在struts.xml中的Action配置裡面,新增一個名稱為input的result配置,也就是說,如果validate方法中,有資料沒有通過驗證,那麼會自動跳轉回到該action中名稱為input的result所配置的頁面。
<package name="default" extends="struts-default">
<action name="helloworld" class="com.hnpi.action.HelloWorldAction">
<result name="toWelcome">/welcome.jsp</result>
<result name="input">/login.jsp</result>
</action>
</package>
5. 接下來需要建立訊息的配置檔案,在Action類的路徑下建立一個同名的properties檔案,也就是檔名為HelloWorldAction.properties。
然後在裡面按照key=value的格式,新增要使用的錯誤訊息。
k1=\u5E10\u53F7\u4E0D\u5141\u8BB8\u4E3A\u7A7A
k2=\u5BC6\u7801\u4E0D\u5141\u8BB8\u4E3A\u7A7A
k3=\u5BC6\u7801\u957F\u5EA6\u5FC5\u987B\u57286\u4F4D\u4EE5\u4E0A
其實是把中文的訊息轉換成了相應的unicode編碼,比如k1後面的value值,其實就是“帳號不允許為空”的unicode編碼。只有這樣,在程式裡面讀取到這些值的時候才會正確顯示中文。有很多工具可以把中文轉換成unicode編碼,比如,native2ascii工具就可以實現。
6.修改validate方法,原來是直接寫的中文字串,現在應該修改成從配置檔案中獲取資訊了
public void validate(){
if(account==null || account.trim().length()==0){
this.addFieldError("account", this.getText("k1"));
}
if(password==null || password.trim().length()==0){
this.addFieldError("password", this.getText("k2"));
}
if(password!=null && !"".equals(password.trim()) && password.trim().length()<6){
this.addFieldError("password", this.getText("k3"));
}
}