1. 程式人生 > >[Sturts2]繼承ActionSupport類

[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"));  
        }  
    }  

就這樣我們繼承ActionSupport類的資訊驗證專案就完成了。

在這裡插入圖片描述