【SpringMVC】SpringMVC校验

news/2024/11/16 18:52:52/

校验理解

项目中,通常使用较多是前端的校验,比如页面中js校验。对于安全要求较高点建议在服务端进行校验。

服务端校验:

  • 控制层conroller:校验页面请求的参数的合法性。在服务端控制层conroller校验,不区分客户端类型(浏览器、手机客户端、远程调用)
  • 业务层service(使用较多):主要校验关键业务参数,仅限于service接口中使用的参数。
  • 持久层dao:一般是不校验的。

springmvc校验需求

springmvc使用hibernate的校验框架validation(和hibernate没有任何关系)。

校验思路:

页面提交请求的参数,请求到controller方法中,使用validation进行校验。如果校验出错,将错误信息展示到页面。

具体需求:

商品修改,添加校验(校验商品名称长度,生产日期的非空校验),如果校验出错,在商品修改页面显示错误信息。

环境准备

我们需要三个jar包:

  • hibernate-validator.jar
  • jboss-logging.jar
  • validation-api.jar

这里我们添加maven依赖

<!-- hibernate 校验 -->
<dependency><groupId>org.hibernate</groupId><artifactId>hibernate-validator</artifactId><version>5.2.4.Final</version>
</dependency>

查看maven依赖树

[INFO] \- org.hibernate:hibernate-validator:jar:5.2.4.Final:compile
[INFO]    +- javax.validation:validation-api:jar:1.1.0.Final:compile
[INFO]    +- org.jboss.logging:jboss-logging:jar:3.2.1.Final:compile
[INFO]    \- com.fasterxml:classmate:jar:1.1.0:compile

可以看到,另外两个jar包被hibernate-validator依赖,所以不用再额外添加了。

配置校验器

  • 在springmvc.xml中添加
<!-- 校验器 -->
<bean id="validator"class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean"><!-- hibernate校验器--><property name="providerClass" value="org.hibernate.validator.HibernateValidator" /><!-- 指定校验使用的资源文件,在文件中配置校验错误信息,如果不指定则默认使用classpath下的ValidationMessages.properties --><property name="validationMessageSource" ref="messageSource" />
</bean>
<!-- 校验错误信息配置文件 -->
<bean id="messageSource"class="org.springframework.context.support.ReloadableResourceBundleMessageSource"><!-- 资源文件名--><property name="basenames"><list><value>classpath:CustomValidationMessages</value></list></property><!-- 资源文件编码格式 --><property name="fileEncodings" value="utf-8" /><!-- 对资源文件内容缓存时间,单位秒 --><property name="cacheSeconds" value="120" />
</bean>
  • 校验器注入到处理器适配器中
<mvc:annotation-driven conversion-service="conversionService"validator="validator">
</mvc:annotation-driven>
  • 在CustomValidationMessages.properties配置校验错误信息:
#添加校验的错误提示信息
items.name.length.error=请输入1到30个字符的商品名称
items.createtime.isNUll=请输入商品的生产日期

在pojo中添加校验规则

在ItemsCustom.java中添加校验规则:

public class Items {private Integer id;//校验名称在1到30字符中间//message是提示校验出错显示的信息//groups:此校验属于哪个分组,groups可以定义多个分组@Size(min=1,max=30,message="{items.name.length.error}")private String name;private Float price;private String pic;//非空校验@NotNull(message="{items.createtime.isNUll}")private Date createtime;

捕获和显示校验错误信息

@RequestMapping("/editItemsSubmit")
public String editItemsSubmit(Model model,HttpServletRequest request,Integer id,@Validated ItemsCustom itemsCustom,BindingResult bindingResult)throws Exception {
  • 在controller中将错误信息传到页面即可
//获取校验错误信息
if(bindingResult.hasErrors()){// 输出错误信息List<ObjectError> allErrors = bindingResult.getAllErrors();for (ObjectError objectError :allErrors){// 输出错误信息System.out.println(objectError.getDefaultMessage());}// 将错误信息传到页面model.addAttribute("allErrors", allErrors);//可以直接使用model将提交pojo回显到页面model.addAttribute("items", itemsCustom);// 出错重新到商品修改页面return "items/editItems";
}
  • 页面显示错误信息:
<!-- 显示错误信息 -->
<c:if test="${allErrors!=null }"><c:forEach items="${allErrors }" var="error">${ error.defaultMessage}<br/></c:forEach>
</c:if>

分组校验

  • 需求:
    • 在pojo中定义校验规则,而pojo是被多个controller所共用,当不同的controller方法对同一个pojo进行校验,但是每个controller方法需要不同的校验
  • 解决方法:
    • 定义多个校验分组(其实是一个java接口),分组中定义有哪些规则
    • 每个controller方法使用不同的校验分组

1.校验分组

public interface ValidGroup1 {//接口中不需要定义任何方法,仅是对不同的校验规则进行分组//此分组只校验商品名称长度}

2.在校验规则中添加分组

//校验名称在1到30字符中间
//message是提示校验出错显示的信息
//groups:此校验属于哪个分组,groups可以定义多个分组
@Size(min=1,max=30,message="{items.name.length.error}",groups = {ValidGroup1.class})
private String name;

3.在controller方法使用指定分组的校验

// value={ValidGroup1.class}指定使用ValidGroup1分组的校验
@RequestMapping("/editItemsSubmit")
public String editItemsSubmit(Model model,HttpServletRequest request,Integer id,@Validated(value = ValidGroup1.class)ItemsCustom itemsCustom,BindingResult bindingResult)throws Exception {

http://www.ppmy.cn/news/7713.html

相关文章

【ESP-Matter】matter协议学习笔记--以乐鑫方案为例

matter协议学习笔记--以乐鑫方案为例0. 写在前边的话1. matter 协议基本概念2. 设备间的本地自动化交互2.1 同步控制的实例&#xff1a;2.2 异步通知&#xff08;订阅、报告&#xff09;3. 桥接设备4. thread 边界路由器5. 专业名词0. 写在前边的话 以下学习笔记均参考乐鑫官方…

一文了解什么是NFT

一、什么是NFT NFT 是我们可以用来代表独特物品所有权的代币。他们让我们对艺术品、收藏品甚至房地产等事物进行代币化。资产的所有权由以太坊区块链保护——没有人可以修改所有权记录或复制/粘贴新的 NFT。 NFT 代表不可替代的代币。Non-fungible 是一个经济学术语&#xff…

Java数组,list,set相互转换

1.list转为set List listnew ArrayList<>(new HashSet()); 2.set转为list Set setnew HashSet<>(new ArrayList()); 3.数组转为list int a{1,2,3,4}; List listArrays.asList(a); 4.数组转set int a{1,2,3,4,5,6}; Set setnew HashSet<>(Arrays.asLis…

Spark 之 Join

broadcast join spark.sql.autoBroadcastJoinThreshold 所配置的值&#xff0c;默认是10M&#xff0c;当某一张表的大小小于这个值时&#xff0c;将这张表收集到driver&#xff0c;然后广播到每一个executor上&#xff0c;这样的好处就是&#xff0c;大表进行join的时候&#…

【nowcoder】笔试强训Day12

目录 一、选择题 二、编程题 2.1二进制插入 2.2 查找组成一个偶数最接近的两个素数 一、选择题 1.以下方法&#xff0c;哪个不是对add方法的重载? public class Test {public void add( int x,int y,int z){} } A. public int add(int x,int y,float z){return 0;} B.…

解决医疗健康领域的网络安全和云技术技能差距

说明信息 近年来&#xff0c;网络安全事件 频发&#xff0c;事件造成的影响也日益增大&#xff0c;对于医疗健康行业&#xff0c;网络安全的重要性凸显。随着医疗信息化的普及&#xff0c;医疗设备与相关系统的安全性已经关系到医疗机构 业务的正常运营。勒索软件&#xff0c;…

Vim生成递增递减的数字【记录器的使用】

一、添加一列连续递增的数字 1、vim打开待编辑文本&#xff0c;先将光标定位到某空行行首&#xff0c;并保证vim处于普通模式&#xff08;normal模式&#xff09;&#xff0c;然后按顺序执行以下命令&#xff1a; i #进入插入模式; 9 #输入数字9 ESC…

C++【跳表】

文章目录一、什么是跳表二、跳表的实现三、跳表性能分析一、什么是跳表 skiplist本质上也是一种查找结构&#xff0c;用于解决算法中的查找问题&#xff0c;跟平衡搜索树和哈希表的价值是一样的&#xff0c;可以作为key或者key/value的查找模型。 skiplist是由William Pugh发…