《Java从入门到放弃》入门篇:springMVC数据校验

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

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

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

具体使用步骤如下:

1)导入数据校验的JAR包

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

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

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

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

6)输入地址,测试效果

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

第一步:将数据校验Jar包复制到项目的lib目录下(本文附件中可以下载)。

hibernate-validator-4.3.0.Final.jar

jboss-logging-3.1.0.CR2.jar

validation-api-1.0.0.GA.jar

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

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

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

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

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

    @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>来显示错误。

<!-- 在顶部加上对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了。

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

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

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

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

最最最后友情提示,文章下面有数据校验要用到的JAR包,请自行下载哈!

时间: 2024-10-12 09:57:08

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

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

目录 SpringMVC数据校验并通过国际化显示错误信息 SpringMVC数据校验 在页面中显示错误信息 通过国际化显示错误信息 SpringMVC数据校验并通过国际化显示错误信息 SpringMVC数据校验 <mvc:annotation-driven/>会默认装配好一个LocalValidatorFactoryBean,通过在处理方法的入参上标注@Valid 注解即可让Spring MVC在完成数据绑定后执行数据校验的工作. 首先,我们在实体类上标注JSR303校验注解 public c

SpringMVC数据校验

一.数据校验 在web应用程序中,为了防止客户端传来的数据引发程序异常,常常需要对 数据进行验证.输入验证分为客户端验证与服务器端验证.客户端验证主要通过JavaScript脚本进行,而服务器端验证则主要通过Java代码进行验证. 为了保证数据的安全性,一般情况下,客户端和服务器端验证都是必须的 二.关键步骤: ①.导入JAR包 SpringMVC支持JSR(Java Specification Result,Java规范提案)303-Bean Validation数据验证规范.而该规范的实现者

springMVC数据校验与单文件上传

spring表单标签:    <fr:from/> 渲染表单元素    <fr:input/>输入框组件    <fr:password/>密码框组件标签    <fr:hidden/>隐藏框组件标签0    <fr:textarea/>多行输入框组件标签    <fr:radiobutton/>单选框组件标签    <fr:checkbox/>复选框组件标签    <fr:select/>下拉列表组件标签 

SpringMVC 数据校验。(后台校验 hibernate validate).

1. 数据校验.(后台校验 hibernate validate). 引入jar包. 在相应的实体类中加入注解. 1 package com.zhiyou100.wc.bean; 2 3 import javax.validation.constraints.Pattern; 4 5 import org.hibernate.validator.constraints.Length; 6 import org.hibernate.validator.constraints.NotEmpty; 7

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

最近,vue.js越来越火.在这样的大浪潮下,我也开始进入vue的学习行列中,在网上也搜了很多教程,按着教程来做,也总会出现这样那样的问题(坑啊,由于网上那些教程都是Vue.js 1.x版本的,现在用Vue.js 的构建工具都已经升级到2.0版本了),经过了一段时间的摸索和看官方的教程和api,才了解到2.0版本在1.0版本的基础上做了好多调整,废弃了好多api...废话不多说了,把我踩过的坑,在这里跟大家说说,希望对初学者有所帮助.ps:高手请绕道. 既然是入门实例,那肯定从最基础的开始了,希

转-Vue.js2.0从入门到放弃---入门实例(一)

http://blog.csdn.net/u013182762/article/details/53021374 标签: Vue.jsVue.js 2.0Vue.js入门实例Vue.js 2.0教程 2016-11-03 14:40 21431人阅读 评论(9) 收藏 举报 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] 最 近,vue.js越来越火.在这样的大浪潮下,我也开始进入vue的学习行列中,在网上也搜了很多教程,按着教程来做,也总会出现这样那样的问题(坑啊, 由

vue.js 2.0 从入门到放弃 --- 入门案例(一)

最近,vue.js越来越火.在这样的大浪潮下,我也开始进入vue的学习行列中,在网上也搜了很多教程,按着教程来做,也总会出现这样那样的问题(坑啊,由于网上那些教程都是Vue.js 1.x版本的,现在用Vue.js 的构建工具都已经升级到2.0版本了),经过了一段时间的摸索和看官方的教程和api,才了解到2.0版本在1.0版本的基础上做了好多调整,废弃了好多api...废话不多说了,把我踩过的坑,在这里跟大家说说,希望对初学者有所帮助.ps:高手请绕道. 既然是入门实例,那肯定从最基础的开始了,希

mysql从入门到放弃-入门知识介绍

数据库在互联网网站的重要性 简单地说,数据库就是一个存放数据的仓库,这个仓库是按照一定的数据结构来组织和存储的,我们可以通过数据库提供的多种方法来管理数据库里的数据.由于数据库不易扩展,所以,在一个互联网网站里,它的瓶颈必然是数据库. 数据库的种类 在当今的互联网中,最常用的数据库模型主要有两种:1)关系型数据库:2)非关系型数据库(NOSQL).

java 24 - 10 GUI 之 四则预算的数据校验

我想要在校验的过程中,如果输入到操作数中的不是数字,则弹出提醒框: 类 JOptionPane  有助于方便地弹出要求用户提供值或向其发出通知的标准对话框 方法名 描述 showConfirmDialog 询问一个确认问题,如 yes/no/cancel. showInputDialog 提示要求某些输入. showMessageDialog 告知用户某事已发生. showOptionDialog 上述三项的大统一 (Grand Unification). 在设置窗体类添加代码: 1 priva