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

在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. 解决发http get请求的时候不成功,出现android.os.NetworkOnMainThreadException的异常

    问题描述:在接游戏sdk的时候,由于游戏要求购买的时候是在主线程里面进行的,但是发http请求是不能在主线程里面发,否则就会出现android.os.NetworkOnMainThreadExcept ...

  2. C++学习笔记——大杂烩

    C++学习笔记--大杂烩                                                         by方阳 版权声明:本文为博主原创文章,转载请指明转载地址 h ...

  3. 投票系统 & js脚本简单刷票

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. HashTable的故事----Jdk源码解读

    HashTable的故事 很早之前,在讲HashMap的时候,我们就说过hash是散列,把...弄碎的意思.hashtable中的hash也是这个意思,而table呢,是指数据表格,也就是说hasht ...

  5. FreeRTOS——内存管理

    1. 标准malloc() 和 free() 库函数的缺陷: 1)在小型的嵌入式系统中,可能不可用. 2)具体实现相对较大,占用较多宝贵的代码空间. 3)通常不具备线程安全性. 4)具有不确定性,每次 ...

  6. SQL Server系列之SQL Server 2016 中文企业版详细安装步骤(超多图)

    1. 下载地址 下载地址 :https://www.microsoft.com/en-us/server-cloud/products/sql-server-2016/ 官方技术文档:https:// ...

  7. css的背景background的相关属性

    今天需要做一个占满设备宽度的轮播图,这里作为demo仅展示一张图,下面分别是要操作的图片(这里做了缩放处理,实际的图比较大),以及要实现的效果图,很明显两者是不成比例的:      (图一)     ...

  8. Css元素居中设置

    你对DIV CSS居中的方法是否了解,这里和大家分享一下,用CSS让元素居中显示并不是件很简单的事情,让我们先来看一下CSS中常见的几种让元素水平居中显示的方法. DIV CSS居中 用CSS让元素居 ...

  9. 【TRICK】解决锚点定位向下浮动Xpx问题

    1. 问题描述 页面滚动后,菜单栏会固定在页头,当锚点定位时,菜单会遮盖部分定位后的内容,所以需要在锚点定位后自动向下漂移Xpx. 2. 解决办法 a. 利用空div 占位,如下: <a hre ...

  10. ES6中的类

    前面的话 大多数面向对象的编程语言都支持类和类继承的特性,而JS却不支持这些特性,只能通过其他方法定义并关联多个相似的对象,这种状态一直延续到了ES5.由于类似的库层出不穷,最终还是在ECMAScri ...