只需要在繼承ActionSupport類的情況下,直接重寫validate()方法即可。使用validate()方法可以對用戶請求的多個Action方法進行驗證,但其驗證的邏輯是相同的。如果在一個Action類中編寫了多個請求處理方法,而此Action重寫了validate()方法,那麼,默認情況下,在執行每個請求方法的過程中,都會經過validate()方法的驗證處理。
使用Struts2驗證框架,驗證文件的名稱需要遵循一定的命名規則,其驗證文件的名稱必須為ActionName-validation.xml或ActionName-AliasName-validation.xml的形式。其中ActionName是Action對象的名稱,AliasName為Action配置中的名稱,也就是struts.xml配置文件中Action元素對應name屬性的名稱。
在這種命名的方式中,數據的驗證會作用於整個Action對象中,並驗證Action對象的請求業務處理方法。如果Action對象中只存在單一的處理方法,或在多個請求處理的方法中,驗證處理的規則都相同,可以應用此種命名方式。
與上一種命名方式相比較,以ActionName-AliasName-validation.xml方式命名更加靈活。如果一個Action對象中包含多個請求處理方法,而又沒有必要對每一個方法進行驗證處理,值需要對Action對象中的特定方法進行處理,就可以使用此種命名方式。
在Struts2框架中使用數據驗證框架,其驗證文件的編寫有兩種風格,也就是兩種編寫方法,分別為字段驗證器編寫風格與非字段驗證器編寫風格,它們各有優點。
(1)創建動態的Java Web項目,將Struts2的相關類包添加到項目的classpath,並在web.xml文件中注冊Struts2提供的StrutsPrepareAndExecuteFilter過濾器,從而搭建Struts2的開發環境,具體代碼如下:
<?xml version="1.0" encoding="GBK"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0"> <display-name>java_struts2</display-name> <welcome-file-list> <welcome-file>index.html</welcome-file> <welcome-file>index.htm</welcome-file> <welcome-file>index.jsp</welcome-file> <welcome-file>default.html</welcome-file> <welcome-file>default.htm</welcome-file> <welcome-file>default.jsp</welcome-file> </welcome-file-list> <!-- Struts2過濾器 --> <filter> <!-- 過濾器名稱 --> <filter-name>struts2</filter-name> <!-- 過濾器類 --> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> <!-- Struts2過濾器映射 --> <filter-mapping> <!-- 過濾器名稱 --> <filter-name>struts2</filter-name> <!-- 過濾器映射 --> <url-pattern>/*</url-pattern> </filter-mapping> </web-app>
(2)創建程序中的主頁index.jsp,在主頁面中通過Struts2框架提供的表單標簽編寫用戶注冊的表單。關鍵代碼如下:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib uri="/struts-tags" prefix="s" %> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <h2>用戶注冊</h2> <s:form action="userAction" method="post"> <s:textfield name="name" label="用戶名" required="true" requiredposition="left"></s:textfield> <s:password name="password" label="密碼" required="true" requiredposition="left"></s:password> <s:radio name="sex" list="#{1:'男',0:'女'}" label="性別" required="true" requiredposition="left"></s:radio> <s:select list="{'請選擇省份','吉林','廣東','山東','河南'}" name="province" label="省份"></s:select> <s:checkboxlist list="{'足球','羽毛球','乒乓球','籃球'}" name="hobby" label="愛好"></s:checkboxlist> <s:textarea name="description" cols="30" rows="5" label="描述"></s:textarea> <s:submit value="注冊"></s:submit> <s:reset value="重置"></s:reset> </s:form> </body> </html>
在應用表單時,如果使用Struts2標簽生成表單元素,可以用標簽中的label屬性,來定義表單元素前面的標簽文字;如果表單中的元素屬於一個必填的元素,那麼可以使用required屬性進行標記,其標記的效果會在元素的邊緣顯示一個字符“*”,同時這個字符“*”的位置也可以控制,通過requiredposition設置即可。
(3)創建用戶注冊後的返回頁面success.jsp,在該頁面中,通過Struts2的數據標簽將用戶注冊信息輸出到頁面中。關鍵代碼如下:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib uri="/struts-tags" prefix="s" %> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <div> <h2>用戶注冊信息</h2> <ul> <li>用戶名:<s:property value="name"/></li> <li>密 碼:<s:property value="passward"/></li> <li>性 別:<s:if test="sex==0">女</s:if><s:else>男</s:else></li> <li>省 份:<s:property value="province"/></li> <li>愛 好:<s:property value="hobby"/></li> <li>描 述:<s:property value="description"/></li> </ul> </div> </body> </html>
(4)創建名稱為UserAction的類,該類繼承於ActionSupport類,是一個Action對象,它的作用是對用戶注冊請求以及用戶信息編輯請求進行處理。關鍵代碼如下:
package com.cn.action; import com.opensymphony.xwork2.ActionSupport; public class UserAction1 extends ActionSupport { private static final long serialVersionUID = 1L; private String name; //用戶名 private String password; //密碼 private String description; //描述 private int sex=1; //性別 private String province; //省份 private String[] hobby; //愛好 public String execute() throws Exception { //用戶注冊 return SUCCESS; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public String getDescription() { return description; } public void setDescription(String description) { this.description = description; } public int getSex() { return sex; } public void setSex(int sex) { this.sex = sex; } public String getProvince() { return province; } public void setProvince(String province) { this.province = province; } public String[] getHobby() { return hobby; } public void setHobby(String[] hobby) { this.hobby = hobby; } }
(5)創建Struts2框架的配置文件struts.xml,在該文件中配置UserAction對象。關鍵代碼如下:
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd"> <struts> <!-- 聲明常量(開發模式) --> <constant name="struts.devMode" value="true"></constant> <!-- 聲明常量(在Struts的配置文件修改後,自動加載) --> <constant name="struts.configuration.xml.reload" value="true"></constant> <!-- 聲明包 --> <package name="myPackage" extends="struts-default" namespace="/"> <!-- 定義action --> <action name="userAction" class="com.cn.action.UserAction"> <!-- 注冊成功的返回頁面 --> <result>success.jsp</result> </action> </package> </struts>
示例運行後,用戶注冊界面如下所示:
若注冊後的頁面出現中文亂碼,把所有網頁的編碼方式設為"UTF-8"即可。
(1)創建動態的Java Web項目,將Struts2的相關類包添加到項目的classpath,並在web.xml文件中注冊Struts2提供的StrutsPrepareAndExecuteFilter過濾器,從而搭建Struts2的開發環境,具體代碼如下:
<?xml version="1.0" encoding="GBK"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0"> <display-name>java_struts2</display-name> <welcome-file-list> <welcome-file>index.html</welcome-file> <welcome-file>index.htm</welcome-file> <welcome-file>index.jsp</welcome-file> <welcome-file>default.html</welcome-file> <welcome-file>default.htm</welcome-file> <welcome-file>default.jsp</welcome-file> </welcome-file-list> <!-- Struts2過濾器 --> <filter> <!-- 過濾器名稱 --> <filter-name>struts2</filter-name> <!-- 過濾器類 --> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> <!-- Struts2過濾器映射 --> <filter-mapping> <!-- 過濾器名稱 --> <filter-name>struts2</filter-name> <!-- 過濾器映射 --> <url-pattern>/*</url-pattern> </filter-mapping> </web-app>
(2)創建用戶登錄的Action對象UserAction,並將UserAction配置到struts.xml配置文件中,具體代碼如下:
UserAction.java
package com.cn.action; import com.opensymphony.xwork2.ActionSupport; public class UserAction2 extends ActionSupport { private static final long serialVersionUID = 1L; private String username; //用戶名 private String password; //密碼 //用戶登錄 @Override public String execute() throws Exception { return SUCCESS; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } }
在struts.xml中的配置如下:
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd"> <struts> <!-- 聲明常量(開發模式) --> <constant name="struts.devMode" value="true"></constant> <!-- 聲明常量(在Struts的配置文件修改後,自動加載) --> <constant name="struts.configuration.xml.reload" value="true"></constant> <!-- 聲明包 --> <package name="myPackage" extends="struts-default" namespace="/"> <!-- 定義action --> <action name="userAction" class="com.cn.action.UserAction"> <!-- 用戶登錄頁面 --> <result name="input">login.jsp</result> <!-- 登錄成功的返回頁面 --> <result>success.jsp</result> </action> </package> </struts>
在struts.xml中配置文件中,請求處理成功的映射結果是success.jsp頁面,驗證失敗返回用戶登錄頁面login.jsp。
注意:默認情況下,Struts2的驗證框架驗證失敗後會返回input對應的頁面,所以需要指定input值對應的頁面。
(3)創建用戶登錄頁面login.jsp,在該頁面中通過Struts2的表單標簽創建用戶登錄表單。關鍵代碼如下:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib uri="/struts-tags" prefix="s" %> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <s:form action="userAction" method="post"> <s:textfield name="username" label="用戶名" required="true"></s:textfield> <s:password name="password" label="密碼" required="true"></s:password> <s:submit key="submit" value="登錄"></s:submit> </s:form> </body> </html>
(4)創建名稱為success.jsp的JSP頁面,該頁面是用戶成功登錄的返回頁面。關鍵代碼如下:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib uri="/struts-tags" prefix="s" %> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <h2> <s:property value="username"/>,登錄成功! </h2> </body> </html>
(5)編寫用戶登錄的驗證文件,該文件的名稱為UserAction-validation.xml。關鍵代碼如下:
<?xml version="1.0" encoding="GBK"?> <!DOCTYPE validators PUBLIC "-//Apache Struts//XWork Validator 1.0.2//EN" "http://struts.apache.org/dtds/xwork-validator-1.0.2.dtd"> <validators> <field name="username"> <field-validator type="requiredstring"> <message>用戶名不能為空</message> </field-validator> </field> <field name="password"> <field-validator type="requiredstring"> <message>密碼不能為空</message> </field-validator> <field-validator type="stringlength"> <param name="maxLength">10</param> <param name="minLength">5</param> <message>密碼長度應該在${minLength}--${maxLength}位之間</message> </field-validator> </field> </validators>
注意:驗證文件UserAction-validation.xml必須放置在UserAction所在的包中。
運行程序後,進入到用戶登錄頁面login.jsp,如下所示:
如果沒有輸入用戶名、密碼的情況下,單擊”登錄“按鈕,頁面會停留在login.jsp頁面中,如下所示:
如果密碼輸入的長度不對,頁面顯示如下內容:
推薦閱讀:
Struts中異步傳送XML和JSON類型的數據 http://www.linuxidc.com/Linux/2013-08/88247.htm
Struts2的入門實例 http://www.linuxidc.com/Linux/2013-05/84618.htm
Struts2學習筆記-Value Stack(值棧)和OGNL表達式 http://www.linuxidc.com/Linux/2015-07/120529.htm
struts2文件上傳(保存為BLOB格式) http://www.linuxidc.com/Linux/2014-06/102905.htm
Struts2的入門實例 http://www.linuxidc.com/Linux/2013-05/84618.htm
Struts2實現ModelDriven接口 http://www.linuxidc.com/Linux/2014-04/99466.htm
遇到的Struts2文件下載亂碼問題 http://www.linuxidc.com/Linux/2014-03/98990.htm
Struts2整合Spring方法及原理 http://www.linuxidc.com/Linux/2013-12/93692.htm
Struts2 注解模式的幾個知識點 http://www.linuxidc.com/Linux/2013-06/85830.htm
Struts 的詳細介紹:請點這裡
Struts 的下載地址:請點這裡