引入服务器端表单验证service,是通过在webx.xml中通过服务引入的方式完成的。例如,在user相关信息的表单验证的产生过程是这样的:webx-user.xml通过 <beans:import resource="user/form.xml" />引入form,xml表单验证配置,在form.xml中,通过services:form开始了表单的验证工作。

Webx表单验证服务主张验证逻辑和页面表现逻辑完全分离。所有的验证规则都写在一个单独的配置文件中 —— 页面模板是不需要关心这些验证规则的。当你需要修改验证规则时,只需要修改独立的配置文件就可以了,并不用修改页面模板。

开始配置表单验证服务。 
每个表单验证服务可包含多个groups。 
每个group可包含多个fields。 
每个field可包含多个validators。

user/form.xml具体配置如下: 
<?xml version="1.0" encoding="UTF-8"?> 
<beans:beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:services="http://www.alibaba.com/schema/services" 
    xmlns:fm-conditions="http://www.alibaba.com/schema/services/form/conditions" 
    xmlns:fm-validators="http://www.alibaba.com/schema/services/form/validators" 
    xmlns="http://www.alibaba.com/schema/services/form/validators" 
    xmlns:beans="http://www.springframework.org/schema/beans" 
    xmlns:p="http://www.springframework.org/schema/p" 
    xsi:schemaLocation=" 
        http://www.alibaba.com/schema/services http://localhost:8080/schema/services.xsd 
        http://www.alibaba.com/schema/services/form/conditions http://localhost:8080/schema/services-form-conditions.xsd 
        http://www.alibaba.com/schema/services/form/validators http://localhost:8080/schema/services-form-validators.xsd 
        http://www.springframework.org/schema/beans http://localhost:8080/schema/www.springframework.org/schema/beans/spring-beans.xsd 
    ">

<services:form postOnlyByDefault="true"> 
        <!-- 
          - =============================================== 
          - 用来检查csrf token。 
          - =============================================== 
         --> 
        <services:group name="csrfTokenCheckGroup"> 
            <services:field name="csrfToken"> 
                <csrf-validator> 
                    <message>提交的数据已过期</message> 
                </csrf-validator> 
            </services:field> 
        </services:group> 
        <!-- 
          - =============================================== 
          - 登录表单 
          - =============================================== 
         --> 
        <services:group name="login" extends="csrfTokenCheckGroup"> 
            <services:field name="loginError"> 
                <custom-error id="invalidUserOrPassword"> 
                    <message>用户名或密码不正确,请重新输入</message> 
                </custom-error> 
            </services:field> 
            <services:field name="userId" displayName="登录名"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
            </services:field> 
            <services:field name="password" displayName="密码"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
            </services:field> 
        </services:group> 
        <!-- 
          - =============================================== 
          - 注册表单 
          - =============================================== 
         --> 
        <services:group name="register" extends="csrfTokenCheckGroup"> 
            <services:field name="registerError"> 
                <custom-error id="duplicatedUserId"> 
                    <message>登录名“${userId}”已经被人注掉了,请尝试另一个名字</message> 
                </custom-error> 
            </services:field> 
            <services:field name="userId" displayName="登录名"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
                <regexp-validator pattern="^[A-Za-z_][A-Za-z_0-9]*$"> 
                    <message>${displayName} 必须由字母、数字、下划线构成</message> 
                </regexp-validator> 
                <string-length-validator minLength="4" maxLength="10"> 
                    <message>${displayName} 最少必须由${minLength}个字组成,最多不能超过${maxLength}个字</message> 
                </string-length-validator> 
            </services:field> 
            <services:field name="password" displayName="密码"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
                <string-length-validator minLength="4" maxLength="10"> 
                    <message>${displayName} 最少必须由${minLength}个字组成,最多不能超过${maxLength}个字</message> 
                </string-length-validator> 
                <string-compare-validator notEqualTo="userId"> 
                    <message>${displayName} 不能与 ${userId.displayName} 相同</message> 
                </string-compare-validator> 
            </services:field> 
            <services:field name="passwordConfirm" displayName="密码验证"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
                <string-compare-validator equalTo="password"> 
                    <message>${displayName} 必须和 ${password.displayName} 相同</message> 
                </string-compare-validator> 
            </services:field> 
        </services:group> 
        <!-- 
          - =============================================== 
          - 注册account信息表单 
          - =============================================== 
         --> 
        <services:group name="registerContact" extends="csrfTokenCheckGroup"> 
            <services:field name="firstName" displayName="名字" propertyName="account.firstName"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
            </services:field> 
            <services:field name="lastName" displayName="姓氏" propertyName="account.lastName"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
            </services:field> 
            <services:field name="address1" displayName="地址" propertyName="account.address1"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
            </services:field> 
            <services:field name="address2" displayName="地址" propertyName="account.address2"> </services:field> 
            <services:field name="city" displayName="城市" propertyName="account.city"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
            </services:field> 
            <services:field name="zip" displayName="邮编" propertyName="account.zip"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
                <number-validator> 
                    <message>${displayName} 必须是数字</message> 
                </number-validator> 
            </services:field> 
            <services:field name="state" displayName="省份" propertyName="account.state"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
            </services:field> 
            <services:field name="country" displayName="国家" propertyName="account.country"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
            </services:field> 
            <services:field name="phone" displayName="电话" propertyName="account.phone"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
            </services:field> 
            <services:field name="email" displayName="电子邮件" propertyName="account.email"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
                <mail-address-validator> 
                    <message>${displayName} 必须是合法的e-mail</message> 
                </mail-address-validator> 
            </services:field> 
        </services:group> 
        <!-- 
          - =============================================== 
          - 注册credit信息表单 
          - =============================================== 
         --> 
        <services:group name="registerCredit" extends="csrfTokenCheckGroup"> 
            <services:field name="creditCardNumber" displayName="信用卡号码" 
                propertyName="account.creditCardNumber"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
                <number-validator> 
                    <message>${displayName} 必须是数字</message> 
                </number-validator> 
            </services:field> 
            <services:field name="creditCardType" displayName="信用卡类型" 
                propertyName="account.creditCardType"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
            </services:field> 
            <services:field name="creditCardExpiryMonth" displayName="信用卡过期月份" 
                propertyName="account.creditCardExpiryMonth"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
            </services:field> 
            <services:field name="creditCardExpiryYear" displayName="信用卡过期年份" 
                propertyName="account.creditCardExpiryYear"> 
                <required-validator> 
                    <message>必须填写 ${displayName}</message> 
                </required-validator> 
            </services:field> 
        </services:group> 
    </services:form>

</beans:beans>

Webx之表单验证的更多相关文章

  1. jQuery学习之路(8)- 表单验证插件-Validation

    ▓▓▓▓▓▓ 大致介绍 jQuery Validate 插件为表单提供了强大的验证功能,让客户端表单验证变得更简单,同时提供了大量的定制选项,满足应用程序各种需求.该插件捆绑了一套有用的验证方法,包括 ...

  2. 玩转spring boot——AOP与表单验证

    AOP在大多数的情况下的应用场景是:日志和验证.至于AOP的理论知识我就不做赘述.而AOP的通知类型有好几种,今天的例子我只选一个有代表意义的“环绕通知”来演示. 一.AOP入门 修改“pom.xml ...

  3. form表单验证-Javascript

    Form表单验证: js基础考试内容,form表单验证,正则表达式,blur事件,自动获取数组,以及css布局样式,动态清除等.完整代码如下: <!DOCTYPE html PUBLIC &qu ...

  4. ASP.NET MVC5+EF6+EasyUI 后台管理系统(33)-MVC 表单验证

    系列目录 注:本节阅读需要有MVC 自定义验证的基础,否则比较吃力 一直以来表单的验证都是不可或缺的,微软的东西还是做得比较人性化的,从webform到MVC,都做到了双向验证 单单的用js实现的前端 ...

  5. 实现跨浏览器html5表单验证

    div:nth-of-type(odd){ float: left; clear: left; } .origin-effect > div:nth-of-type(even){ float: ...

  6. jQuery Validate 表单验证 — 用户注册简单应用

    相信很多coder在表单验证这块都是自己写验证规则的,今天我们用jQuery Validate这款前端验证利器来写一个简单的应用. 可以先把我写的这个小demo运行试下,先睹为快.猛戳链接--> ...

  7. jquery validate表单验证插件-推荐

    1 表单验证的准备工作 在开启长篇大论之前,首先将表单验证的效果展示给大家.     1.点击表单项,显示帮助提示 2.鼠标离开表单项时,开始校验元素  3.鼠标离开后的正确.错误提示及鼠标移入时的帮 ...

  8. 表单验证插件之jquery.validate.js

    提到表单验证的插件,第一个想到的就是jquery.validate.js,所以小生想在这里稍微详细地说一下这款插件的具体使用方法,便于理解,我直接附上整段demo的代码(没怎么调样式,主要是看js): ...

  9. 走进AngularJs 表单及表单验证

    年底了越来越懒散,AngularJs的学习落了一段时间,博客最近也没更新.惭愧~前段时间有试了一下用yeoman构建Angular项目,感觉学的差不多了想做个项目练练手,谁知遇到了一系列问题.yeom ...

随机推荐

  1. linux下如何删除文件夹

    直接rm就可以了,不过要加两个参数-rf 即:rm -rf 目录名字-r 就是向下递归,不管有多少级目录,一并删除-f 就是直接强行删除,不作任何提示的意思删除文件夹实例: rm -rf /var/l ...

  2. LSJ_NHibernate第四章 MVC

    前言: MVC现在已经成为web开发的一个主流趋势了,还没用过的小伙伴,你们已经落伍了,这里我推荐一篇学习博客 玩转Asp.net MVC 的八个扩展点  代码完全开源,下载地址:https://gi ...

  3. 使用普通Windows服务创建Quartz.Net服务项目

    Quartz.NET 项目地址 http://quartznet.sourceforge.net/ 源码下载地址:Quartz.Net.2.0 首先创建Quartz.Net.2.0解决方案,添加 Wi ...

  4. AndroidListview 滑动过程中图片显示重复错乱解决方案

    主要分析Android中Listview滚动过程造成的图片显示重复.错乱.闪烁的原因及解决方法,顺便跟进Listview的缓存机制. 1.原因分析 Listview item 缓存机制:为了使得性能更 ...

  5. Linux的各种命令(android adb shell)

    win+r 调出运行,输入CMD adb shell 进入手机的控制终端,相当于原生的Linux系统的各种操作. 当提示符为$符号,说明未获得超级管理员权限,输入su,可编程# adb kill-se ...

  6. ibatis+spring+cxf+mysql搭建webservice

    首先需必备:mysql.myeclipse6.5.apache-cxf-2.6.2 一.建数据库,库名:cxf_demo:表名:book CREATE DATABASE `cxf_demo`  --数 ...

  7. 10.14_魅族手机音乐播放无故暂停,MetroUICss-tile中的字如何居中

    (1)魅族手机,播放音乐,无故暂停.不管是自带的音乐播放程序,还是下载的其他音乐播放器都是如此.而且,手机上有个Google服务耗电量非常高,会经常弹出登陆Google账号的弹出项. (2)Metro ...

  8. c++动态绑定与静态绑定

    C++为了支持多态性,采用了动态绑定和静态绑定 相关概念: 对象的静态类型:对象在声明时采用的类型,编译时确定 对象的动态类型:目前所指对象的类型,在运行时确定 class B { } class C ...

  9. Android LayoutInflater.inflate使用上的问题解惑

    最近在在使用LayoutInflater.inflate方法时遇到了一些问题,以前没有仔细看过此类的使用方法,故将其记录下来,方便日后查阅. 相信大家都知道LayoutInflater.inflate ...

  10. 【javascript 变量和作用域】

    今天学习了javascript 的变量和作用域的基本知识,对于以前在开发中遇到的一些不懂的小问题也有了系统的认识,收获还是比较多的. [基本类型和引用类型] ECMAScript 变量可能包含两种不同 ...