@Validated验证List集合的方法示例

在开发时发现,@Validated只能验证单个实体类,在验证List集合时则不生效

@PostMapping(value="/test")
public ApiResult getRepaymentPlan(@RequestBody @Validated List<Test> repaymentPlanVOs){

}

经过查资料得知,@valid是可以使用的,我们自定义一个ValidList类来替换List就可以达到验证的目的,话不多说,直接看代码

public class ValidList<E> implements List<E> {

 @Valid
 private List<E> list = new LinkedList<>();

 @Override
 public int size() {
  return list.size();
 }

 @Override
 public boolean isEmpty() {
  return list.isEmpty();
 }

 @Override
 public boolean contains(Object o) {
  return list.contains(o);
 }

 @Override
 public Iterator<E> iterator() {
  return list.iterator();
 }

 @Override
 public Object[] toArray() {
  return list.toArray();
 }

 @Override
 public <T> T[] toArray(T[] a) {
  return list.toArray(a);
 }

 @Override
 public boolean add(E e) {
  return list.add(e);
 }

 @Override
 public boolean remove(Object o) {
  return list.remove(o);
 }

 @Override
 public boolean containsAll(Collection<?> c) {
  return list.containsAll(c);
 }

 @Override
 public boolean addAll(Collection<? extends E> c) {
  return list.addAll(c);
 }

 @Override
 public boolean addAll(int index, Collection<? extends E> c) {
  return list.addAll(index, c);
 }

 @Override
 public boolean removeAll(Collection<?> c) {
  return list.removeAll(c);
 }

 @Override
 public boolean retainAll(Collection<?> c) {
  return list.retainAll(c);
 }

 @Override
 public void clear() {
  list.clear();
 }

 @Override
 public E get(int index) {
  return list.get(index);
 }

 @Override
 public E set(int index, E element) {
  return list.set(index, element);
 }

 @Override
 public void add(int index, E element) {
  list.add(index, element);
 }

 @Override
 public E remove(int index) {
  return list.remove(index);
 }

 @Override
 public int indexOf(Object o) {
  return list.indexOf(o);
 }

 @Override
 public int lastIndexOf(Object o) {
  return list.lastIndexOf(o);
 }

 @Override
 public ListIterator<E> listIterator() {
  return list.listIterator();
 }

 @Override
 public ListIterator<E> listIterator(int index) {
  return list.listIterator(index);
 }

 @Override
 public List<E> subList(int fromIndex, int toIndex) {
  return list.subList(fromIndex, toIndex);
 }

public List<E> getList() {
 return list;
}

public void setList(List<E> list) {
 this.list = list;
}

}

然后用ValidList类替换我们的List即可

@PostMapping(value="/test")
public ApiResult getRepaymentPlan(@RequestBody @Validated ValidList<Test> repaymentPlanVOs){

}

补充,将@Validated返回的异常替换为我们自定义的json格式并返回,只需在当前controller类里注入一个异常bean,并用@ExceptionHandler来捕获对应的异常即可。MethodArgumentNotValidException为@Validated返回的异常,这里只需要捕获对应异常即可

@ExceptionHandler(value = MethodArgumentNotValidException.class)
 @ResponseBody
 public Map<String,Object> allExceptionHandler(MethodArgumentNotValidException e){
    Map<String,Object> result = new HashMap<String,Object>();
 MethodArgumentNotValidException ex = (MethodArgumentNotValidException)e;
 BindingResult bindingResult = ex.getBindingResult();
 StringBuilder errMsg = new StringBuilder(bindingResult.getFieldErrors().size() * 16);
 errMsg.append("Invalid request:");
 for (int i = 0 ; i < bindingResult.getFieldErrors().size() ; i++) {
  if(i > 0) {
  errMsg.append(",");
  }
  FieldError error = bindingResult.getFieldErrors().get(i);
  errMsg.append(error.getField()+":"+error.getDefaultMessage());
 }
    result.put("res_code","400");
    result.put("res_mess",errMsg.toString());
 return result;
 }

到此这篇关于@Validated验证List集合的方法示例的文章就介绍到这了,更多相关@Validated验证List集合内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 使用SpringMVC的@Validated注解验证的实现

    1.SpringMVC验证@Validated的使用 第一步:编写国际化消息资源文件 编写国际化消息资源ValidatedMessage.properties文件主要是用来显示错误的消息定制 edit.username.null=用户名不能为空 edit.password.size=密码最少{min}位,最长{max}位 ...... 可以将edit.username.null与edit.password.size看为参数,在message中传递,具体请看第二步. 第二步:Bean实体类中加注解

  • Java使用@Validated注解进行参数验证的方法

    目前项目中大部分代码进行参数验证都是写代码进行验证,为了提升方便性和代码的简洁性,所以整理了下使用注解进行参数验证.使用效果如下: // 要验证的实体类 @Data public class User implements Serializable { @NotBlank(message = "id不能为空!",groups = Update.class) protected String id = ""; @NotBlank(message = "商户i

  • 详解Spring 参数验证@Validated和@Valid的区别

    Spring Validation验证框架对参数的验证机制提供了@Validated(Spring's JSR-303 规范,是标准 JSR-303 的一个变种),javax提供了@Valid(标准JSR-303规范),配合 BindingResult 可以直接提供参数验证结果.其中对于字段的特定验证注解比如 @NotNull 等网上到处都有,这里不详述 在检验 Controller 的入参是否符合规范时,使用 @Validated 或者 @Valid 在基本验证功能上没有太多区别.但是在分组.

  • Spring @Valid @Validated实现验证

    对于属性的验证有如下一些注解 @NotBlank:只用在String上,值不能为null,并且trim后长度大于零.不为null,不是全为空格的字符串 @NotNull: 不能为null,但可以是长度为零的字符串 @NotEmpty: 不能为null,长度大于零 @Null:必须为null @Min(value): 数字,值必须大于等于指定的值 @Max(value): 数字,值必须小雨等于指定的值 @DecimalMin(value): 数字,值必须大于等于指定的值 @DecimalMax(v

  • @Validated验证List集合的方法示例

    在开发时发现,@Validated只能验证单个实体类,在验证List集合时则不生效 @PostMapping(value="/test") public ApiResult getRepaymentPlan(@RequestBody @Validated List<Test> repaymentPlanVOs){ } 经过查资料得知,@valid是可以使用的,我们自定义一个ValidList类来替换List就可以达到验证的目的,话不多说,直接看代码 public class

  • Java实现添加、验证PDF数字签名的方法示例

    目录 Jar文件获取及导入方法: 在设置文档内容保护的方法中,除了对文档加密.添加水印外,应用数字签名也是一种有效防伪手段.数字签名的文件比较容易验证,并且具有较高的权威性和可信度.在PDF文档中,有可直接添加或验证数字签名的功能方法,下面的文章中,将通过Java程序来介绍添加数字签名到PDF文档,以及验证签名是否有效. 使用工具:Spire.PDF for Java Jar文件获取及导入方法: 方法1:可通过官网下载jar文件包.下载后,解压文件,并将lib文件夹下的Spire.Pdf.jar

  • PHP实现超简单的SSL加密解密、验证及签名的方法示例

    本文实例讲述了PHP实现超简单的SSL加密解密.验证及签名的方法.分享给大家供大家参考,具体如下: 1. sign签名代码: function sign($data) { //读取私钥文件 $priKey = file_get_contents('key/rsa_private_key.pem'); //转换为openssl密钥,必须是没有经过pkcs8转换的私钥 $res = openssl_get_privatekey($priKey); //调用openssl内置签名方法,生成签名$sig

  • koa-passport实现本地验证的方法示例

    安装 yarn add koa-passport passport-local 先看下passport.js登录策略,判断用户和密码 const passport = require('koa-passport') const LocalStrategy = require('passport-local').Strategy const User = require('../../dbs/models/users') passport.use(new LocalStrategy((userna

  • Node登录权限验证token验证实现的方法示例

    1. token的使用场景 无状态请求 保持用户的登录状态 第三方登录(token+auth2.0) 2. 基于token的验证原理 后端不再存储认证信息,而是在用户登录的时候生成一个token,然后返回给前端,前端进行存储,在需要进行验证的时候将token一并发送到后端,后端进行验证 加密的方式:对称加密和非对称加密,对称加密指的是加密解密使用同一个密钥,非对称加密使用公钥和私钥,加密用私钥加密,解密用公钥解密 3. 基于Token的身份验证的过程如下: 客户端:用户名和密码请求登录 服务器:

  • vue 验证两次输入的密码是否一致的方法示例

    好记性不如烂笔头.总也记不住 <el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm"> <el-form-item label="新密码" prop="newPwd"> <el-input v-mo

  • Nest.js 授权验证的方法示例

    0x0 前言 系统授权指的是登录用户执行操作过程,比如管理员可以对系统进行用户操作.网站帖子管理操作,非管理员可以进行授权阅读帖子等操作,所以实现需要对系统的授权需要身份验证机制,下面来实现最基本的基于角色的访问控制系统. 0x1 RBAC 实现 基于角色的访问控制(RBAC)是围绕角色的特权和定义的策略无关的访问控制机制,首先创建个代表系统角色枚举信息 role.enum.ts: export enum Role { User = 'user', Admin = 'admin' } 如果是更复

  • springboot整合阿里云oss上传的方法示例

    OSS申请和配置 1. 注册登录 输入网址:https://www.aliyun.com/product/oss 如果没有账号点击免费注册,然后登录. 2.开通以及配置 点击立即开通 进入管理控制台 第一次使用会出现引导,按引导点击"我知道了",然后点击创建Bucket. 如果没有存储包或流量包点击购买. 点击确定,返回主页面,出现该页面,点击我知道了 将EndPoint记录下来,方便后期添加到我们项目的配置文件中 创建 AccessKeyID 和 AccessKeySecret 点击

  • java自定义注解验证手机格式的实现示例

    1.@Valid与@Validated的区别 1.1 基本区别 @Valid:Hibernate validation校验机制 @Validated:Spring Validator校验机制,这个也是最常用的 @Validation只是对@Valid进行了二次封装,在使用上并没有太大区别,但在分组.注解位置.嵌套验证等功能上有所不同 1.2 作用范围 @Validated:用在类型.方法和方法参数上.但不能用于成员属性(field) @Valid:可以用在方法.构造函数.方法参数和成员属性(fi

  • Java使用代理进行网络连接方法示例

    需求是这样的: 一.界面上要有这样几种代理类型可以选. 1.HTTP代理 2.Socks代理 3.不使用代理(直连) 4.使用浏览器设置(浏览器也是HTTP.Socks.直连三种). 可参考QQ登录设置里的代理能,其实跟qq的代理功能是一样的. 二.测试使用所填写的代理配置信息是否可连接 三.记录用户上次选择的代理配置,默认使用用户上次使用的代理配置进行网络连接. 程序运行环境是WindowsXP.Windows7.Windows8系统. 使用的技术为Java7,Swing,CXF. 难点: 1

随机推荐