SpringMVC教程4[服务器端校验]

简介: SpringMVC教程4[服务器端校验]


文章目录

   数据校验

       1. 为什么需要服务端校验?

       2.普通校验

           2.1创建项目

           2.2引入相关jar包

           2.3创建properties文件

           2.4在springmvc的配置文件中配置如下

           2.5Bean对象中配置校验规则

           2.6Controller中校验

           2.7jsp页面中获取错误信息

           2.8测试

       3.分组校验

           3.1定义分组

           3.2使用分组

           3.3controller中使用

           3.4测试

数据校验

1. 为什么需要服务端校验?

   最早的校验,就是服务端校验。早期的网站,用户输入一个邮箱地址,校验邮箱地址需要将地址发送到服务端,服务端进行校验,校验成功后,给前端一个响应。有了JavaScript,校验工作可以放在前端去执行。那么为什么还需要服务端校验呢? 因为前端传来的数据不可信。前端很容易获取都后端的数据接口,如果有人绕过页面,就会出现非法数据,所以服务端也要数据校验,总的来说:

   1.前端校验要做,目的是为了提高用户体验

   2.后端校验也要做,目的是为了数据安全

2.普通校验

   Springmvc本身没有校验功能,它使用hibernate的校验框架,hibernate的校验框架和orm没有关系

2.1创建项目

2.2引入相关jar包

image.png

如果是maven项目对应的maven坐标是:

<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-validator</artifactId>
    <version>5.3.0.Alpha1</version>
</dependency>

2.3创建properties文件

   属性文件用来声明错误提示信息

image.png

如果属性文件乱码的解决办法:

在Eclipse主界面下,打开Window->Perferences->General->ContentTypes:

image.png

2.4在springmvc的配置文件中配置如下

<beans xmlns="http://www.springframework.org/schema/beans"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
  xmlns:mvc="http://www.springframework.org/schema/mvc"
  xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd
    http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd">
  <mvc:annotation-driven validator="validator"></mvc:annotation-driven>
  <context:component-scan base-package="com.dpb.controller"></context:component-scan>
  <!--添加对JSR-303验证框架的支持  -->
    <bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">
        <property name="providerClass"  value="org.hibernate.validator.HibernateValidator"/>
        <!--不设置则默认为classpath下的 ValidationMessages.properties -->
        <property name="validationMessageSource" ref="validatemessageSource"/>
    </bean>
    <bean id="validatemessageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource">  
        <property name="basename" value="classpath:ValidateMessages"/>  
        <property name="fileEncodings" value="utf-8"/>  
        <property name="cacheSeconds" value="120"/>  
    </bean> 
</beans>

image.png

2.5Bean对象中配置校验规则

  @NotBlank(message="{user.username.empty}")
  @Size(max=6,min=3,message="{user.username.size}")
  private String username;
  @Size(max=6,min=3,message="{user.password.size}")
  private String password;

   校验规则

注解 说明

@Null 被注解的元素必须为 null

@NotNull 被注解的元素必须不为 null

@AssertTrue 被注解的元素必须为 true

@AssertFalse 被注解的元素必须为 false

@Min(value) 被注解的元素必须是一个数字,其值必须大于等于指定的最小值

@Max(value) 被注解的元素必须是一个数字,其值必须小于等于指定的最大值

@DecimalMin(value) 被注解的元素必须是一个数字,其值必须大于等于指定的最小值

@DecimalMax(value) 被注解的元素必须是一个数字,其值必须小于等于指定的最大值

@Size(max=, min=) 被注解的元素的大小必须在指定的范围内

@Digits (integer, fraction) 被注解的元素必须是一个数字,其值必须在可接受的范围内

@Past 被注解的元素必须是一个过去的日期

@Future 被注解的元素必须是一个将来的日期

@Pattern(regex=,flag=) 被注解的元素必须符合指定的正则表达式

@NotBlank(message =) 验证字符串非null,且长度必须大于0

@Email 被注解的元素必须是电子邮箱地址

@Length(min=,max=) 被注解的字符串的大小必须在指定的范围内

@NotEmpty 被注解的字符串的必须非空

@Range(min=,max=,message=) 被注解的元素必须在合适的范围内

2.6Controller中校验

/**
 * 数据校验案例
 * 
 * @author dpb【波波烤鸭】
 *
 */
@Controller
public class UserController {
  /**
   * @Validated book 表示book接收的数据需要根据指定的规则进行校验
   * BindingResult 封装验证结果,必须紧跟在验证变量之后,
   *        如果有多个信息需要验证那么就有多个BindingResult参数
   * 
   */
  @RequestMapping("/add")
  public String add(@Validated Book book,BindingResult br,Model m){
    System.out.println(book);
    // 获取验证信息
    List<ObjectError> allErrors = br.getAllErrors();
    for (ObjectError objectError : allErrors) {
      System.out.println(objectError.getDefaultMessage());
    }
    // 将验证信息保存到作用域中
    m.addAttribute("errors", allErrors);
    return "/index.jsp";
  }
}

2.7jsp页面中获取错误信息

<%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
  hello world<br/>
  <c:if test="${errors ne null }">
    <c:forEach items="${errors}" var="e">
      ${e.defaultMessage}<br>
    </c:forEach>
  </c:if>
</body>
</html>

2.8测试

image.pngimage.png

3.分组校验

   为什么需要分组校验?

   因为一个对象有多个属性,而不同的controller校验的需求是不一样的,必须c1只需要校验对象的账号是否为空就可以了,而c2不光要校验账号为空还需要校验手机号必须不能为空,这时分组校验就能解决这个问题了。实现步骤如下:

3.1定义分组

image.png

package com.dpb.group;
/**
 * 定义的两个接口什么都没定义为标志接口
 * @author dpb【波波烤鸭】
 *
 */
public interface GroupInferface1 {
}

3.2使用分组

  @NotBlank(message="{user.username.empty}"
      ,groups={GroupInferface2.class})
  @Size(max=6,min=3,message="{user.username.size}"
      ,groups={GroupInferface1.class})
  private String username;
  @Size(max=6,min=3,message="{user.password.size}"
      ,groups={GroupInferface1.class})
  private String password;

3.3controller中使用

  /**
   * @Validated book 表示book接收的数据需要根据指定的规则进行校验
   * BindingResult 封装验证结果,必须紧跟在验证变量之后,
   *        如果有多个信息需要验证那么就有多个BindingResult参数
   * 
   */
  @RequestMapping("/add1")
  public String add1(@Validated(value=GroupInferface1.class) Book book,BindingResult br,Model m){
    System.out.println(book);
    // 获取验证信息
    List<ObjectError> allErrors = br.getAllErrors();
    for (ObjectError objectError : allErrors) {
      System.out.println(objectError.getDefaultMessage());
    }
    // 将验证信息保存到作用域中
    m.addAttribute("errors", allErrors);
    return "/index.jsp";
  }

 

image.png

3.4测试

第一种情况

image.pngimage.png第二种情况:

image.pngimage.png


相关文章
|
1月前
|
弹性计算 关系型数据库 MySQL
阿里云服务器搭建网站教程:经济型e实例2核2G快速搭建网站图文教程参考
目前在阿里云的活动中,轻量应用服务器2核2G3M带宽只要68元1年,2核4G4M带宽只要298元1年。云服务器ECS经济型e实例2核2G 3M固定带宽,价格只要99元/1年,新老用户都可购买,企业用户购买2核4G5M带宽199元一年,为用户提供长期权益。这些都是个人和普通企业用户搭建网站使用较多的云服务器,本文为大家展示使用经济型e实例2核2G3M带宽快速搭建网站的相关教程,以供参考。
175 18
|
7天前
|
弹性计算 负载均衡 Java
【上云基础系列 02-01】通过SLB+1台ECS+ESS弹性伸缩,搭建一个精简版的上云标准弹性架构(含方案及教程)
通常,构建一个弹性架构(即使是一个最基础的入门版),至少需要2台ECS。但是,很多小微企业刚开始上云的时候,为了节省成本不愿意购买更多的服务器。通过 “ALB+ESS弹性伸缩+1台ECS+RDS”方案,在保障低成本的同时,也不牺牲业务架构的弹性设计,更避免了很多人因为节省成本选择了单体架构后频繁改造架构的困局。 方案中的几个设计非常值得小微企业借鉴:(1)通过ALB/RDS的按量付费,节省了初期流量不大时的费用;(2)通过ESS弹性伸缩,不需要提前购买服务器资源,但是当业务增长或减少时却保持了资源弹性自动扩缩容。
|
1月前
|
弹性计算 Ubuntu Linux
阿里云服务器一键安装Docker社区版教程,基于系统运维管理OOS
阿里云服务器一键安装Docker社区版教程,基于系统运维管理OOS自动化部署。支持Ubuntu 22.04/20.04、CentOS 7.7-7.9及Alibaba Cloud Linux 3.2104 LTS。前提条件:ECS实例需运行中且有公网。步骤:选择Docker扩展并安装,验证成功通过命令`docker -v`查看版本号。
300 79
|
6天前
|
弹性计算 安全 应用服务中间件
阿里云服务器四种常见购买方式图文教程及适用场景参考(2025更新)
阿里云服务器如何购买?比较常见的购买方式有自定义购买、快速购买、通过活动购买、通过云市场镜像页面购买这四种购买方式,每种方式都有主要的适合对象,购买流程也不是完全一样的。例如想要快速购买的用户,一般选择快速购买、通过活动购买最好,如果是想购买的云服务器已经部署好一些自己项目运行所需的各种环境和软件,则选择通过云市场镜像页面购买这种方式更好。本文为以图文形式为大家展示用户选择较多的四种购买方式及适用场景,以供参考。
|
4月前
|
弹性计算 Linux Windows
跨账号和同账号的ECS云服务器之间迁移教程
跨账号和同账号的ECS云服务器之间迁移教程
|
8天前
|
弹性计算 运维 网络安全
阿里云轻量应用服务器产品解析与搭建个人博客网站教程参考
轻量应用服务器(Simple Application Server)作为阿里云面向单机应用场景推出的云服务器产品,以其一键部署、一站式管理、高性价比等特性,深受个人开发者、中小企业及入门级用户的喜爱。本文将全面解析阿里云轻量应用服务器的产品优势、应用场景、使用须知,以及使用轻量应用服务器搭建个人博客网站的详细教程,帮助用户更好地了解和使用这一产品。
|
4月前
|
弹性计算 网络安全
阿里云国际OpenAPI多接口快速管理ECS服务器教程
阿里云国际OpenAPI多接口快速管理ECS服务器教程
|
1月前
|
弹性计算 Linux 数据安全/隐私保护
阿里云服务器最新购买流程与试用流程参考,购买与试用图文教程和注意事项
如何购买和试用阿里云服务器,教程参考来了。阿里云服务器分为免费版和收费版,新用户可免费领取一台云服务器作为试用,轻量应用服务器2核2G目前38元1年,云服务器ECS2核2G3M的价格为99元1年,2核4G5M配置199元1年,下面小编来介绍一下2025年我们购买和试用阿里云服务器的详细流程,以图文形式展示给大家,适合新手用户参考。
阿里云服务器最新购买流程与试用流程参考,购买与试用图文教程和注意事项
|
1月前
|
弹性计算 安全 搜索推荐
阿里云国际站注册教程:阿里云服务器安全设置
阿里云国际站注册教程:阿里云服务器安全设置 在云计算领域,阿里云是一个备受推崇的品牌,因其强大的技术支持和优质的服务而受到众多用户的青睐。本文将为您介绍阿里云国际站的注册过程,并重点讲解如何进行阿里云服务器的安全设置。
|
2月前
|
域名解析 弹性计算 安全
阿里云服务器租用、注册域名、备案及域名解析完整流程参考(图文教程)
对于很多初次建站的用户来说,选购云服务器和注册应及备案和域名解析步骤必须了解的,目前轻量云服务器2核2G68元一年,2核4G4M服务器298元一年,域名注册方面,阿里云推出域名1元购买活动,新用户注册com和cn域名2年首年仅需0元,xyz和top等域名首年仅需1元。对于建站的用户来说,购买完云服务器并注册好域名之后,下一步还需要操作备案和域名绑定。本文为大家展示阿里云服务器的购买流程,域名注册、绑定以及备案的完整流程,全文以图文教程形式为大家展示具体细节及注意事项,以供新手用户参考。

热门文章

最新文章