昨天我们扯完了数据传递,今天我们来聊聊数据校验的问题。来,跟着我一起读:计一噢叫,一按艳。

在springMVC中校验数据也非常简单,spring3.0拥有自己独立的数据校验框架,同时支持JSR303标准的校验框架。

Spring的DataBinder在进行数据绑定时,会同时调用校验框架完成数据校验工作。

具体使用步骤如下:

1)导入数据校验的JAR包

2)在springmvc的配置文件中添加校验Bean

3)修改实体类,在属性上加上校验的注解

4)修改昨天的login4方法,加上校验的相关代码

5)修改JSP页面,加上错误提示

6)输入地址,测试效果

好了,来看看详细的实现吧,非常简单滴!

第一步:将数据校验Jar包复制到项目的lib目录下(可以在链接: http://pan.baidu.com/s/1mhQ44yO 密码: sd45去下载)。

hibernate-validator-4.3.0.Final.jar

jboss-logging-3.1.0.CR2.jar

validation-api-1.0.0.GA.jar

第二步:修改springMVC配置文件,添加如下代码

1
2
    <!-- 数据校验 -->
    <bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean"></bean>

第三步:修改昨天的User实体类,加上账号和密码的检验(账号只能是8~20位的字母、数字或下划线,密码可以是任意字符,长度必须在6~10位)。

1
2
3
4
    @Pattern(regexp="^\\w{8,20}$", message="账号只能是8~20位的字母、数字或下划线")
    private String loginid;
    @Length(min=6, max=10, message="密码长度必须在6~10位")
    private String loginpwd;

第四步:修改login4方法,加上校验相关的代码。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
    @RequestMapping("/login4")
    public ModelAndView login4(@Valid @ModelAttribute("user") User use, BindingResult bindingResult,
            HttpServletRequest request, HttpServletResponse response, HttpSession session){
        ModelAndView mav = new ModelAndView("index.jsp");
         
        //判断校验结果
        if(bindingResult.hasErrors()){
            mav.setViewName("login.jsp");
            return mav;
        }
         
        if(use.getLoginid().equals("admin") && use.getLoginpwd().equals("666")){
            use.setNickname("我是黄河你是海流");
            //mav.addObject("user", use);            //添加需要传递到下一个视图的数据
            session.setAttribute("user", use);
        }
        else{
            mav.addObject("msg""猪脑子,账号和密码都输不对!");
            mav.setViewName("login.jsp");        //修改视图
        }
        return mav;
    }

注意:在User对象前面加上@Valid注解,在该对象之后加上BindingResult对象。BindingResult的hasErrors方法表示校验是否出错,如果有错误则为true。

第五步:修改JSP页面,使用springMVC的标签<form:errors>来显示错误。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
<!-- 在顶部加上对form标签的引用 -->
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
 
    <form:form modelAttribute="user" action="login4.form" method="post">
        <!-- 
                path:表示检验信息(*表示所有,如果只想显示某一个属性的验证信息,直接写属性名)
            cssStyle:表示该区域的样式
             element:表示该区域使用的容器标签 
        -->
        <form:errors path="*" cssStyle="color:red;" element="div"></form:errors>
        账号:<input name="loginid" type="text" /><br />
        密码:<input name="loginpwd" type="password" /><br />
        <input type="submit" value="登录" />
    </form:form>

第六步:访问login.jsp页面,测试错误数据时的效果。

到这儿,关于springMVC的数据校验就OK了。

当然,校验的注解不只这么只个,如果大家有兴趣,可以自行百度。

什么!!!!你居然不会百度!!!!!

好吧,谁叫这是入门篇呢,我帮你百度吧···

够意思了吧,还帮你变成了图片,免得你保存不方便·,不用谢我,我姓雷,名傲天...

《Java从入门到放弃》入门篇:springMVC数据校验的更多相关文章

  1. Java性能测试从入门到放弃-概述篇

    Java性能测试从入门到放弃-概念篇 辅助工具 Jmeter: Apache JMeter是Apache组织开发的基于Java的压力测试工具.用于对软件做压力测试.JMeter 可以用于对服务器.网络 ...

  2. SpringMVC数据校验并通过国际化显示错误信息

    目录 SpringMVC数据校验并通过国际化显示错误信息 SpringMVC数据校验 在页面中显示错误信息 通过国际化显示错误信息 SpringMVC数据校验并通过国际化显示错误信息 SpringMV ...

  3. 《SpringMVC从入门到放肆》十三、SpringMVC数据校验

    上一章,我们学习了SpringMVC的自定义类型转换器,但是如果转换后的数据传递到Controller的方法中,忽然发现有某些属性为Null了,这怎么办?我们需要一种有效的数据校验机制,来对数据进行有 ...

  4. springMVC数据校验与单文件上传

    spring表单标签:    <fr:from/> 渲染表单元素    <fr:input/>输入框组件    <fr:password/>密码框组件标签    & ...

  5. Flink从入门到放弃(入门篇1)-Flink是什么

    戳更多文章: 1-Flink入门 2-本地环境搭建&构建第一个Flink应用 3-DataSet API 4-DataSteam API 5-集群部署 6-分布式缓存 7-重启策略 8-Fli ...

  6. Flink从入门到放弃(入门篇2)-本地环境搭建&构建第一个Flink应用

    戳更多文章: 1-Flink入门 2-本地环境搭建&构建第一个Flink应用 3-DataSet API 4-DataSteam API 5-集群部署 6-分布式缓存 7-重启策略 8-Fli ...

  7. Flink从入门到放弃(入门篇3)-DataSetAPI

    戳更多文章: 1-Flink入门 2-本地环境搭建&构建第一个Flink应用 3-DataSet API 4-DataSteam API 5-集群部署 6-分布式缓存 7-重启策略 8-Fli ...

  8. Flink从入门到放弃(入门篇4) DataStreamAPI

    戳更多文章: 1-Flink入门 2-本地环境搭建&构建第一个Flink应用 3-DataSet API 4-DataSteam API 5-集群部署 6-分布式缓存 7-重启策略 8-Fli ...

  9. Vue.js2.0从入门到放弃---入门实例

    最近,vue.js越来越火.在这样的大浪潮下,我也开始进入vue的学习行列中,在网上也搜了很多教程,按着教程来做,也总会出现这样那样的问题(坑啊,由于网上那些教程都是Vue.js 1.x版本的,现在用 ...

随机推荐

  1. 【LeetCode】118. Pascal's Triangle

    题目: Given numRows, generate the first numRows of Pascal's triangle. For example, given numRows = 5,R ...

  2. [图形学] Chp17 OpenGL光照和表面绘制函数

    这章学了基本光照模型,物体的显示受到以下效果影响:全局环境光,点光源(环境光漫反射分量,点光源漫反射分量,点光源镜面反射分量),材质系数(漫反射系数,镜面反射系数),自身发光,雾气效果等.其中点光源有 ...

  3. java 线程 理解 解析

    1 线程的概述 进程:正在运行的程序,负责了这个程序的内存分配,代表了内存中的执行区域. 线程:就是在一个进程中负者一个执行路径. 多线程:就是在一个进程中多个执行路径同时执行. 假象: 电脑上的程序 ...

  4. React Native之APK文件签名及打包

    生成apk签名文件 我们使用android studio的方式进行签名 AS工具栏找到并点击 build->gennrate signed apk 两种情况: 1.这里如果已经有签名文件了则直接 ...

  5. POJ 2152 fire / SCU 2977 fire(树型动态规划)

    POJ 2152 fire / SCU 2977 fire(树型动态规划) Description Country Z has N cities, which are numbered from 1 ...

  6. “玲珑杯”ACM比赛 Round #12 (D) 【矩阵快速幂的时间优化】

    //首先,感谢Q巨 题目链接 定义状态向量b[6] b[0]:三面临红色的蓝色三角形个数 b[1]:两面临红色且一面临空的蓝色三角形个数 b[2]:一面临红色且两面临空的蓝色三角形个数 b[3]:三面 ...

  7. HTLM5新增属性

    1.<meta http-equiv="Pragma" content="no-cache"/> //禁止页面缓存 2.<script def ...

  8. 微信小程序开发问答《五十四》同步请求授权 & 用户拒绝授权,重新调起授权 ... ...

    1.同步请求授权 需求分析: 1.在小程序首次打开的时候,我需要同时请求获取多个权限,由用户逐一授权. (['scope.userInfo','scope.userLocation','scope.a ...

  9. Angular02 将数据添加到组件中

    准备:已经搭建好angular-cli环境.知道如何创建组件 一.将一个数据添加到组件中 1 创建一个新的组件 user-item 2 将组件添加到静态模板中 3 为组件添加属性,并利用构造器赋值 4 ...

  10. HDU1035 Robot Motion

    Problem Description A robot has been programmed to follow the instructions in its path. Instructions ...