《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包,请自行下载哈!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java帮帮-微信公众号-技术文章全总结

开发一定要看的Ajax编程

Ajax编程入门 1.web交互的2种模式对比 ①:2种交互模式的流程 ? ②:2种交互模式用户体验 同步交互模式:客户端提交请求,等待,在响应回到客户端前,客...

2745
来自专栏Google Dart

Quartz组件使用二 原

420
来自专栏重庆的技术分享区

AngularJS浅谈-博客

993
来自专栏圣杰的专栏

Ajax.BeginForm()知多少

在ASP.NET MVC中,Ajax.BeginForm扮演着异步提交的重要角色。其中就有五个重载方法,但是在实际应用中,你未必使用的得心应手,今天我们就从主要...

2016
来自专栏从零开始学 Web 前端

从零开始学 Web 之 Vue.js(四)Vue的Ajax请求和跨域

在这里我会从 Web 前端零基础开始,一步步学习 Web 相关的知识点,期间也会分享一些好玩的项目。现在就让我们一起进入 Web 前端学习的冒险之旅吧!

862
来自专栏技术博客

ExtJs四(ExtJs MVC登录窗口的调试)

继上一节中实现了验证码http://www.cnblogs.com/aehyok/archive/2013/04/19/3030212.html,现在我们可以进...

602
来自专栏weixuqin 的专栏

springMVC 学习笔记(一):spring 入门

springMVC 是 spring 框架的一个模块,springMVC 和 spring 无需通过中间整合层进行整合。springMVC 是一个基于 mvc ...

762
来自专栏ccylovehs

JavaScript跨域解决方式

平时工作中经常被JavaScript跨域问题所困扰,其实有很多种解决方式,下面给大家介绍常用的几种:

581
来自专栏开发之途

Android 静默安装应用和静默卸载应用

1285
来自专栏walterlv - 吕毅的博客

(持续整理中)Visual Studio 中 C# 代码分析规则集中每一项的含义 (stylecop ruleset)

发布于 2018-02-07 13:55 更新于 2018-03...

502

扫码关注云+社区