一、數據的校驗,Struts2提供了兩類數據校驗
前臺校驗:JS校驗、
JS的校驗不是必須的,JS的校驗是可以被繞行的、JS提升用戶體驗。
後臺校驗:編碼校驗。
必須的校驗
執行攔截器的時候向FieldError當中添加錯誤信息
1、Struts2提供的第一種數據校驗(手動編碼的方式進行校驗)
(1)JSP頁面
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<h1>登錄頁面</h1>
<h3><s:fielderror></s:fielderror></h3>
<form action="${pageContext.request.contextPath }/login1.action" method="post">
用戶名:<input type="text" name="username"/><br/>
密碼:<input type="password" name="password"/><br/>
<input type="submit" value="提交"/>
</form>
</body>
</html>
(2)struts.xml
(3)LoginAction1
繼承ActionSupport類
抽象validate方法:針對Action當中所有的方法。
在這個方法當中可以編寫校驗代碼。
package com.itzheng.web.action.demo1;
import com.opensymphony.xwork2.ActionSupport;
/*
* 數據的校驗
* 繼承了ActionSupport之後纔有一些功能:數據的校驗,國際化,設置錯誤的信息!
*/
public class LoginAction1 extends ActionSupport{
private String username;
private String password;
public void setUsername(String username) {
this.username = username;
}
public void setPassword(String password) {
this.password = password;
}
@Override
public String execute() throws Exception {
// TODO Auto-generated method stub
return NONE;
}
//數據校驗的方法:
@Override
public void validate() {
// TODO Auto-generated method stub
//判斷用戶名不能爲空 username.trim() 去掉空格
if(username == null || username.trim().length() == 0 ) {
//阻止execute方法執行。
this.addFieldError("username", "用戶名不能爲空!");
}
//判斷密碼不能爲空
if(password == null || password.trim().length() == 0) {
this.addFieldError("password", "密碼不能爲空");
}
}
}
頁面效果
當Action當中有很多方法的時候,以現在這種情況都會走validate,然後再執行這些方法,因此需要
(4)針對Action當中某個方法進行校驗:例如Action當中的add方法或者modify的方法。
編寫一個與validate 這個方法格式相同的方法,但是方法的名稱要寫validate+要校驗的方法名稱‘’
validateAdd();//校驗add方法
validateModify();//校驗Modify方法
2、Struts2提供的第二種數據校驗(XML配置文件的方式進行校驗)
Action當中需要提供get方法
2.1針對Action當中所有的方法
(1)創建JSP
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<h1>登錄頁面</h1>
<h3><s:fielderror></s:fielderror></h3>
<form action="${pageContext.request.contextPath }/login2.action" method="post">
用戶名:<input type="text" name="username"/><br/>
密碼:<input type="password" name="password"/><br/>
<input type="submit" value="提交"/>
</form>
</body>
</html>
(2)LoginAction2
package com.itzheng.web.action.demo1;
import com.opensymphony.xwork2.ActionSupport;
public class LoginAction2 extends ActionSupport {
private String username;
private String password;
public void setUsername(String username) {
this.username = username;
}
public void setPassword(String password) {
this.password = password;
}
// 爲使XML當中username 和 password獲得對應的值,需要get方法
public String getUsername() {
return username;
}
public String getPassword() {
return password;
}
@Override
public String execute() throws Exception {
System.out.println(username);
System.out.println(password);
return super.execute();
}
}
在Action所在的包下創建一個與Action類名相同的+(-validation.xml)
(3)在XML當中寫入
首先找到對應的文件(頭信息)在xwork-core-2.3.7.jar有一個xwork-validator-1.0.3.dtd
校驗規則 requiredstring就是校驗規則:從com.opensymphony.xwork2.validator.validators,default.xml當中可以查看校驗的規則
進行配置
LoginAction2-validation.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE validators PUBLIC
"-//Apache Struts//XWork Validator 1.0.3//EN"
"http://struts.apache.org/dtds/xwork-validator-1.0.3.dtd">
<validators>
<!-- field當中name代表要校驗的字段名 -->
<field name="username">
<!-- field-validator校驗規則 -->
<field-validator type="requiredstring">
<!-- message如果不符合要求在頁面上輸出什麼內容 -->
<message>用戶名不能爲空!(XML)</message>
</field-validator>
</field>
<field name="password">
<field-validator type="requiredstring">
<message>密碼不能爲空!(XML)</message>
</field-validator>
</field>
</validators>
(4)配置
(5)測試
2.2針對Action當中某一個方法進行校驗:
在Action所在訂單包下創建一個文件與Action類名相同-要訪問的方法所對應的action的名稱-validation.xml
<action name="login2" class="com.itzheng.web.action.demo1.LoginAction2" method="execute"/>
創建execute的文件
LoginAction2-login2-validation.xml
表示攔截的是LoginAction2當中的login2請求
LoginAction2-login2-validation.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE validators PUBLIC
"-//Apache Struts//XWork Validator 1.0.3//EN"
"http://struts.apache.org/dtds/xwork-validator-1.0.3.dtd">
<validators>
<field name="password">
<field-validator type="stringlength">
<param name="minLength">6</param>
<param name="maxLength">12</param>
<message>密碼需要在6-12位之間!</message>
</field-validator>
</field>
</validators>
3、Struts2提供的校驗器列表
4、綜合案例
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE validators PUBLIC
"-//Apache Struts//XWork Validator 1.0.3//EN"
"http://struts.apache.org/dtds/xwork-validator-1.0.3.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="minLength">6</param>
<param name="maxLength">12</param>
<message>密碼需要在6-12位之間!</message>
</field-validator>
</field>
<!-- 校驗確認密碼 -->
<field name="repassword">
<field-validator type="fieldexpression">
<!-- 表達式要寫在 <![CDATA[]]> 內 -->
<param name="expression"><![CDATA[repassword==password]]></param>
<message>兩次密碼輸入不一致</message>
</field-validator>
</field>
<!-- 校驗年齡 -->
<field name="age">
<field-validator type="int">
<param name="min">18</param>
<param name="max">40</param>
<message>年齡輸入不合法!必須是18-40歲之間的!</message>
</field-validator>
</field>
<!-- 校驗郵箱 -->
<field name="email">
<field-validator type="email">
<message>郵箱格式不正確</message>
</field-validator>
</field>
<!-- 校驗電話 -->
<field name="phone">
<field-validator type="regex">
<param name="regexExpression"><![CDATA[\d{11}]]></param>
<message>手機號格式有誤</message>
</field-validator>
</field>
<!-- 校驗生日 -->
<field name="birthday">
<field-validator type="date">
<param name="min">1974/01/01</param>
<param name="max">2002/01/01</param>
<message>生日不合法!</message>
</field-validator>
</field>
</validators>
package com.itzheng.web.action.demo5;
import java.util.Date;
import com.opensymphony.xwork2.ActionSupport;
public class RegistAction extends ActionSupport {
private String username;
private String password;
private String repassword;
private int age;
private String email;
private String phone;
private Date birthday;
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;
}
public String getRepassword() {
return repassword;
}
public void setRepassword(String repassword) {
this.repassword = repassword;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
public Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
@Override
public String execute() throws Exception {
// TODO Auto-generated method stub
return NONE;
}
}