Spring框架整合Struts2使用Validation框架验证表单用户输入数据的详细教程

原创整理不易,转载请注明出处:Spring框架整合Struts2使用Validation框架验证表单用户输入数据的详细教程

代码下载地址:http://www.zuidaima.com/share/1778685765291008.htm

在《Struts2教程4:使用validate方法验证数据》中曾讲到使用validate方法来验证客户端提交的数据,但如果使用validate方法就会将验证代码和正常的逻辑代码混在一起,但这样做并不利于代码维护,而且也很难将过些代码用于其他程序的验证。在Struts2中为我们提供了一个Validation框架,这个框架和Struts1.x提供的Validation框架类似,也是通过XML文件进行配置。

一、服务端验证

下面将给出一个例子来演示如何使用Struts2的validation框架来进行服务端验证。我们可以按着如下四步来编写这个程序:

【第1步】建立Action类(NewValidateAction.java)

package com.zuidaima.action;

 import com.opensymphony.xwork2.ActionSupport;

 public class NewValidateAction extends ActionSupport
{
 private String msg; // 必须输入
 private int age; // 在13和20之间
 public String getMsg()
 {
 return msg;
 }
 public void setMsg(String msg)
 {
 this .msg= msg;
 }
 public int getAge()
 {
 return age;
 }
 public void setAge( int age)
 {
 this .age= age;
 }
}

下面我们来验证msg和age属性。

【第2步】配置Action类,struts.xml的代码如下:

<?xml version="1.0"encoding="UTF-8" ?>
 <! DOCTYPE struts PUBLIC
 "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
 "http://struts.apache.org/dtds/struts-2.0.dtd">
 <struts>
 <package name="demo" extends="struts-default" namespace="/test">
 <action name="new_validate" class="action.NewValidateAction">
 <result name="input">/validate_form.jsp </result>
 <result name="success"> /validate_form.jsp </result>
 </action>
 </package>
 </struts>

【第3步】编写验证规则配置文件

这是一个基于XML的配置文件,和struts1.x中的validator框架的验证规则配置文件类似。但一般放到和要验证的.class文件在同一目录下,而且配置文件名要使用如下两个规则中的一个来命名:

<ActionClassName>-validation.xml

<ActionClassName>-<ActionAliasName>-validation.xml

其中<ActionAliasName>就是struts.xml中<ation>的name属性值。在本例中我们使用第一种命名规则,所以文件名是NewValidateAction-validation.xml。文件的内容如下:

<?xml version="1.0"encoding="UTF-8"?>
 <! DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.2//EN"
"http://www.opensymphony.com/xwork/xwork-validator-1.0.2.dtd">
 <validators>
 <field name="msg">
 <field-validator type="requiredstring">
 <message> 请输入信息 </message>
 </field-validator>
 </field>
 <field name="age">
 <field-validator type="int">
 <param name="min"> </param>
 <param name="max"> </param>
 <message>
 必须在 13至20之间
 </message>
 </field-validator>
 </field>
 </validators>

这个文件使用了两个规则:requiredstring(必须输入)和int(确定整型范围)。关于其他更详细的验证规则,请读者访问http://struts.apache.org/2.0.11.1/docs/validation.html来查看。

【第4步】编写数据录入JSP页。

在Web根目录中建立一个validate_form.jsp文件,代码如下:

<%@page language="java" import="java.util.*" pageEncoding="GBK"%>
 <%@ taglib prefix="s" uri="/struts-tags" %>
 <link rel="stylesheet" type="text/css" href="<s:urlvalue="/styles/styles.css" /> ">
 <html>
 <head>
 <title> 验证数据 </title>
 </head>
 <body>
 <s:form action="new_validate" namespace="/test">
 <s:textfield name="msg" label="姓名" />
 <s:textfield name="age" label="年龄" />
 <s:submit />
 </s:form>
 </body>
 </html>

大家要注意一下,如果在struts.xml的<package>标签中指定namespace属性,需要在<s:form>中也将namespace和action分开写,如上面代码所示。不能将其连在一起,Struts2需要分开的action和namespace。如下面的代码是错误的:

<s:form action="/test/new_validate" >

... ...

</s:form>

在上面的程序中还使用了一个styles.css来定制错误信息的风格。代码如下:

.label{font-style:italic; }

.errorLabel{font-style:italic; color:red; }

.errorMessage{font-weight:bold; color:red; }

需要在Web根目录中建立一个styles目录,并将styles.css

假设Web工程的上下文路径是validation,可以使用如下的URL来测试这个程序:

http://localhost:8080/validation/validate_form.jsp

显示结果如图 1 所示。

图1

二、客户端验证

 

在Struts2中实现客户端验证非常简单,只需要在<s:form>中加入一个validate属性,值为true。如<s:formvalidate="true" ... > ... </form>即可。

三、验证嵌套属性

有一类特殊的属性,即这个属性的类型是另外一个 JavaBean ,如有一个 User 类,代码如下:

package data;

 public class User
{
 private String name;
 private int age;
 public String getName()
 {
 return name;
 }
 public void setName(String name)
 {
 this .name= name;
 }
 public int getAge()
 {
 return age;
 }
 public void setAge( int age)
 {
 this .age= age;
 }
}

在 NewValidateAction 类中加一个 user 属性,代码如下:

package action;

 import com.opensymphony.xwork2.ActionSupport;
 import data.User;

 public class NewValidateAction extends ActionSupport
{
 private String msg;
 private int age;
 private User user;
 public String getMsg()
 {
 return msg;
 }

 public void setMsg(String msg)
 {
 this .msg= msg;
 }
 public int getAge()
 {
 return age;
 }
 public void setAge( int age)
 {
 this .age= age;
 }
 public User getUser()
 {
 return user;
 }

 public void setUser(User user)
 {
 this .user= user;
 }
}

如果要验证NewValidateAction中的user属性,可以使用visitor验证器。操作过程如下:

首先在NewValidateAction-validation.xml中加入一个<field>标签,代码如下:

<?xml version="1.0"encoding="UTF-8"?>
 <! DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.2//EN"
"http://www.opensymphony.com/xwork/xwork-validator-1.0.2.dtd">
 <validators> 

 <field name="user">
 <field-validator type="visitor">
 <param name="context">abc </param>
 <param name="appendPrefix"> true </param>
 <message> User: </message>
 </field-validator>
 </field>
 </validators>

其中context参数将作为验证User类属性的文件名的一部分,如user属性返回一个User对象,那么用于验证User对象属性的文件名为User-abc-validation.xml。这个文件要和User.class文件在同一个目录中。appendPrefix表示是否在字段里加user,如果为true,Struts2就会使用user.name在form提交的数据中查找要验证的数据。这个属性的默认值是true。如果出错,Struts2会将<message>标签中的信息加到User-abc-validation.xml文件中的相应错误信息前面。

User-abc-validation.xml 文件的内容如下:

<?xml version="1.0"encoding="UTF-8"?>
 <! DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.2//EN"
 "http://www.opensymphony.com/xwork/xwork-validator-1.0.2.dtd">
 <validators>
 <field name="name">
 <field-validator type="requiredstring">
 <message> 请输入name </message>
 </field-validator>
 </field>
 <field name="age">
 <field-validator type="int">
 <param name="min"> </param>
 <param name="max"> </param>
 <message>
 必须在 5至20之间
 </message>
 </field-validator>
 </field>
 </validators>

下面修改validate_form.jsp,代码如下:

<s:form validate="true" action="new_validate" namespace="/test">
 <s:textfield name="msg" label="姓名" />
 <s:textfield name="age" label="年龄"/>
 <s:textfield name="user.name" label="姓名1" />
 <s:textfield name="user.age" label="年龄1" />
 <s:submit />
 </s:form>

大家可以看到,最后两个<s:textfield>的name属性是user.name和user.age,正好是加了前缀的。

现在重新访问  http://localhost:8080/validation/validate_form.jsp ,验证界面如图 2 所示。

图2

经笔者测试,使用visitor无法以客户端验证的方式来验证user属性,但NewValidateAction中其他的属性可以使用客户端测试。

Spring框架整合Struts2使用Validation框架验证表单用户输入数据的详细教程

时间: 2024-09-28 21:33:14

Spring框架整合Struts2使用Validation框架验证表单用户输入数据的详细教程的相关文章

jQuery常用插件与jQuery使用validation插件实现表单验证实例

jQuery常用插件 1,jQuery特别容易扩展,开发者可以基于jQuery开发一些扩展动能 2,插件:http://plugins.jquery.com 3,超厉害的插件:validation . pickadate.  Echarts.chosen.(编辑器插件) ckeditor在百度上都可以直接搜索 表单校验 jQuery插件validation:https://jqueryvalidation.org/ validation是一个基于jQuery的插件,里面有了jQuery的一些函数

yii验证表单

1.yii框架中验证的类文件: 上面红线内是验证的具体的类文件,下面的这个文件制定了类的别名. 2.验证邮箱的时候默认不能为空,除了可以在模型里面设置为required外,还可以在模型的rule里面,在对应的email类里面可以看到这个allowEmpty参数. array('kemail', 'email','allowEmpty'=>false), 提示的验证信息除了在配置文件中指定: 'language'=>'zh_cn', 还可以再上面的array后添加一个message参数来制定提示

企业级 SpringBoot 教程 (十九) 验证表单信息

这篇文篇主要简述如何在springboot中验证表单信息.在springmvc工程中,需要检查表单信息,表单信息验证主要通过注解的形式. 构建工程 创建一个springboot工程,由于用到了 web .thymeleaf.validator.el,引入相应的起步依赖和依赖,代码清单如下: <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactI

Struts2中UI标签之表单标签介绍

1.在Struts2中UI标签的表单标签分为两种:form标签本身和单个表单标签. 2.Struts2表单标签包括:form.textfield.password.radio.checkbox.checkboxlist.select.doubleselect.combobox.optiontransferselect.optgroup.updownselect.textarea.hidden.file.label.submit.token.head.datepicker.reset.richte

jQuery用面向对象的思想来编写验证表单的插件

本人的重点是怎么构建一个简单有效可扩展的jQuery表单验证插件,这篇文章没有教你怎么用 validate plugin.我们的重点在学习一些jQuery,Javascript面向对象编程的知识. 下面是一个完整的html页面代码,可以直接运行测试的. <html> <head><title>jQuery用面向对象的思想来编写验证表单的插件</title> <style type="text/css"> form {margi

验证表单是否为空

验证表单是否为空,或者全是数字 可以用   var  reg = /^\s*(\S+)\s*$/;  正则表达式判断. var reg = /^\s*(\S+)\s*$/; if(reg.test(list[i].value)){ //将空格替换 RegExp.$1捕获匹配的非空格 list[i].value=RegExp.$1; }else{ alert('不能为空'); return; }

js 验证表单 js提交验证类

js 验证表单 js提交验证类 附加:js验证radio是否选择 <script language="javascript">function checkform(obj){for(i=0;i<obj.oo.length;i++)         if(obj.oo[i].checked==true) return true; alert("请选择")return false; }</script><form id="f

jquery验证表单 提交表单

问题: jquery中使用submit提交按钮时,当return false后,依然会提交表单. 解决: 使用button按钮,而不是submit按钮 <script type="text/javascript" src="scripts/jquery-2.0.2.js"></script> <script type="text/javascript"> function check(){ var npassw

ExtJS学习笔记3:加载、提交和验证表单

加载数据 1.比较好用的设置form数据的方法: formPanel.getForm().setValues([{id: 'FirstName', value: 'Joe'}]); 其中id值为form中field的name属性值,value为要赋的值 2.通过对象赋值: Ext.define('Request', { extend: 'Ext.data.Model', fields: [ 'FirstName', 'LastName', 'EmailAddress', 'TelNumberCo