首页 > 其他分享 >参数校验和分组

参数校验和分组

时间:2023-08-24 13:11:06浏览次数:39  
标签:分组 校验 private 参数 AddGroup import class

对于参数校验的一个总结

意义:前端校验了,后端也进行数据校验,保存数据安全性

/**
 *
 * @Description
 *
 * JSR提供的校验注解:
 *
 * @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=) 被注释的元素必须符合指定的正则表达式
 * Hibernate Validator提供的校验注解:
 *
 * @NotBlank(message =)  验证字符串非null,且长度必须大于0
 * @Email 被注释的元素必须是电子邮箱地址
 * @Length(min=,max=) 被注释的字符串的大小必须在指定的范围内
 * @NotEmpty 被注释的字符串的必须非空
 * @Range(min=,max=,message=) 被注释的元素必须在合适的范围内
 **/

11-1 普通校验

第1步:引入如依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-validation</artifactId>
</dependency>

第2步: eg:对BrandEntity1标注数据校验注解

package com.xurong.parmcheck.domain.entity;

import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.xurong.parmcheck.common.valid.ListValue;
import lombok.Data;
import javax.validation.constraints.*;
import java.io.Serializable;

@Data
@TableName("pms_brand")
public class BrandEntity1 implements Serializable {
	private static final long serialVersionUID = 1L;

	/**
	 * 品牌id
	 */
	@TableId
	private Long brandId;
	/**
	 * 品牌名
	 */
	@NotBlank(message = "品牌名必须提交")
	private String name;
	/**
	 * 品牌logo地址
	 */
	@NotBlank
//	@URL(message = "logo必须是一个合法的url地址")
	private String logo;
	/**
	 * 介绍
	 */
	private String descript;
	/**
	 * 显示状态[0-不显示;1-显示]
	 */
//	@Pattern()
	@NotNull
	// 这是自定义注解,表明该字段只能是0或1
  	@ListValue(valus={0,1})
	private Integer showStatus;

	/**
	 * 检索首字母
	 */
	@NotEmpty()
	@Pattern(regexp="^[a-zA-Z]$")
	private String firstLetter;
	/**
	 * 排序
	 */
	@NotNull()
	@Min(value = 0,message = "排序必须大于等于0")
	private Integer sort;

}

第3步:给接口发送数据,验证发送的数据是否被验证

验证1:品牌名不存在,没法通过验证

结果:数据被验证,由于没有name导致数据校验失败

验证2:测试通过案例

结果:成功通过数据校验

11-2 分组校验

意义:只对标注了分组标志字段进行校验

同样引入上述依赖

第一步:对每一个字段添加分组校验字段

package com.xurong.parmcheck.domain.entity;

import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;

import com.xurong.parmcheck.common.valid.AddGroup;
import com.xurong.parmcheck.common.valid.ListValue;
import com.xurong.parmcheck.common.valid.UpdateGroup;
import com.xurong.parmcheck.common.valid.UpdateStatusGroup;
import lombok.Data;
import org.hibernate.validator.constraints.URL;

import javax.validation.constraints.*;
import java.io.Serializable;

@Data
@TableName("pms_brand")
public class BrandEntity2 implements Serializable {
	private static final long serialVersionUID = 1L;

	/**
	 * 品牌id
	 */
	@NotNull(message = "修改必须指定品牌id",groups = {UpdateGroup.class})
	@Null(message = "新增不能指定id",groups = {AddGroup.class})
	@TableId
	private Long brandId;
	/**
	 * 品牌名
	 */
	@NotBlank(message = "品牌名必须提交",groups = {AddGroup.class,UpdateGroup.class})
	private String name;
	/**
	 * 品牌logo地址
	 */
	@NotBlank(groups = {AddGroup.class})
	// @URL(message = "logo必须是一个合法的url地址",groups={AddGroup.class,UpdateGroup.class})
	private String logo;
	/**
	 * 介绍
	 */
	private String descript;
	/**
	 * 显示状态[0-不显示;1-显示]
	 */
//	@Pattern()
	@NotNull(groups = {AddGroup.class, UpdateStatusGroup.class})
  	@ListValue(valus={0,1},groups = {AddGroup.class, UpdateStatusGroup.class})
	private Integer showStatus;

	/**
	 * 检索首字母
	 */
	@NotEmpty(groups={AddGroup.class})
	@Pattern(regexp="^[a-zA-Z]$",message = "检索首字母必须是一个字母",groups={AddGroup.class,UpdateGroup.class})
	private String firstLetter;
	/**
	 * 排序
	 */
	@NotNull(groups={AddGroup.class})
	@Min(value = 0,message = "排序必须大于等于0",groups={AddGroup.class,UpdateGroup.class})
	private Integer sort;

}

第2步:使用接口作为分组标志

eg: AddGroup该接口作为保存数据时,进行分组校验的一个分组标志

public interface AddGroup {
}

eg:同理,更新数据时也添加一个分组标志

public interface UpdateGroup {
}

第2步:对接口参数进行分组校验

 /**
     *
     * @Description
     * 保存时使用分组校验
     * @param
     * @Author xu
     * @Date 2023/8/24 12:14
     *
     */
    @PostMapping("/save2")
    public R saveBrand2(@Validated({AddGroup.class}) @RequestBody BrandEntity2 brand) {
        return R.ok("保存成功").put("brand",brand);
    }

    /**
     * 修改时使用分组校验
     */
    @PutMapping("/update")
    public R update(@Validated(UpdateGroup.class) @RequestBody BrandEntity2 brand){
        return R.ok("更新成功").put("brand",brand);
    }

总结:也就是说,通过@Validated({AddGroup.class})对接口的数据进行校验,只校验实体类对象字段上上标有注解,并且该注解在AddGroup分组标志中,没有在AddGroup分组标志中的注解即使标注在该字段上,也不起作用。

注意:

1、要么使用@Valid对数据进行校验,要么使用@Validated({AddGroup.class})进行分组校验

2、开发接口时,可以考虑分组校验,eg:增删改查定义多个接口作为分组标志,进行数据校验时,只需要对标志了该分组标志的注解下的字段属性进行数据校验

标签:分组,校验,private,参数,AddGroup,import,class
From: https://www.cnblogs.com/rong-xu-drum/p/17653899.html

相关文章

  • Angular:表单设置动态校验规则(ngZorro示例)
    背景有时我们需要根据不同的条件,决定表单控件是否是必填的。代码示例HTML文件<formnz-form[formGroup]="validateForm"(ngSubmit)="submitForm()"><nz-form-item><nz-form-label[nzSpan]="4"nzRequirednzFor="name">Name</nz-f......
  • 多参数@MethodSource参数化
    通过@MethodSource注解引用方法作为参数化的数据源信息在 @MethodSource 注解的参数必须是静态的工厂方法,除非测试类被注释为@TestInstance(Lifecycle.PER_CLASS)静态工厂方法的返回值需要和测试方法的参数对应如果在 @MethodSource 注解中未指明方法名,会自动调用与测试方......
  • 枚举参数的参数化@EnumSource
    使用枚举类作为测试数据。枚举参数参数化注解 @EnumSource。必须与 @ParameterizedTest 结合使用。需要添加@EnumSource注解测试方法传入枚举类作为参数packagecom.mytest;importorg.junit.jupiter.params.ParameterizedTest;importorg.junit.jupiter.params.pro......
  • 多参数的参数化@CsvSource
    多参数参数化注解 @CsvSource。@CsvSource 通过指定的分隔符实现参数化。packagecom.mytest;importorg.junit.jupiter.params.ParameterizedTest;importorg.junit.jupiter.params.provider.CsvSource;importstaticorg.junit.jupiter.api.Assertions.assertEquals;i......
  • 将request中的参数转换成map
    /***将request中的参数转换成map*/publicstaticMap<String,String>requestParamsToMap(HttpServletRequestrequest){Map<String,String>reqMap=newHashMap<>();Enumerationenu=request.getParameterNames();while(enu.hasMoreEl......
  • 参数化-单参数@ValueSource
    引入依赖<!--参数化依赖--><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter-params</artifactId><version>5.8.1</version><scope>test</scope></dependency......
  • C#命令行传输参数
    staticvoidMain(string[]args){varoo=args;if(oo.Length>0){XLog.XTrace.WriteLine("收到下发的tif文件:"+oo[0]);//System.Windows.Forms.MessageBox.Show(oo[0]);......
  • python - 文件md5校验
    通过md5校验文件,我们可以判断文件内容是否改变,用python实现代码如下importhashlib#1.txt为空文本withopen('1.txt','rb')asf:data=f.read()md5Old=hashlib.md5(data).hexdigest()print(md5Old)#d41d8cd98f00b204e9800998ecf8427e#1.txt内容为12......
  • MT6873,MTK6873,天玑800核心板基本参数跑分,5G安卓核心板
    MT6873核心板采用了台积电7纳米先进制程,拥有8个核心。其中包括4个主频高达2GHz的Cortex-A76大核心和4个主频高达2GHz的Cortex-A55小核心。在安兔兔跑分测试中,该核心板通常可以达到约32万分的得分。这款核心板还集成了ARMMali-G57MC5GPU,并支持Sub-6GHz频段的NSA和SA双模5G。该核......
  • H5支付 商家参数格式有误 请联系商家解决
    我们公司是做教育培训的,APP的支付使用了H5支付,2023-07月份开始有大量用户反馈:OPPP、一加手机会出现【商家参数格式有误】我这边通过抓包工具 Fiddler发现来源参数没有丢失,抓包下本来异常手机居然也可以正常支付。刷新当前错误页面也可以正常调起支付,无痕模式下也可以正常支付......