当前位置: 首页 > news >正文

企业网站管理系统设置91人才网赣州招聘网

企业网站管理系统设置,91人才网赣州招聘网,企业网站优化兴田德润,wordpress双击图片放大目录 一、Spring Boot Validation简介 1.1 什么是spring-boot-starter-validation? 1.2 核心优势 二、快速集成与配置 2.1 添加依赖 2.2 基础配置 三、核心注解详解 3.1 常用校验注解 3.2 嵌套对象校验 四、实战开发步骤 4.1 DTO类定义校验规则 4.2 Cont…

目录

一、Spring Boot Validation简介

1.1 什么是spring-boot-starter-validation?

1.2 核心优势

二、快速集成与配置

2.1 添加依赖

2.2 基础配置

三、核心注解详解

3.1 常用校验注解

3.2 嵌套对象校验

四、实战开发步骤

4.1 DTO类定义校验规则

4.2 Controller层启用校验

4.3 统一异常处理

五、高级功能实现

5.1 自定义校验规则

5.2 分组校验

六、常见问题与解决方案

6.1 校验不生效的常见原因

6.2 国际化配置

七、性能优化建议

八、测试验证

8.1 单元测试示例

8.2 API测试(使用MockMvc)

九、总结与最佳实践


一、Spring Boot Validation简介

1.1 什么是spring-boot-starter-validation?

  spring-boot-starter-validation 是Spring Boot对Bean Validation API(JSR 380)的封装实现,基于Hibernate Validator提供强大的数据校验功能。它能帮助开发者:

  • 声明式校验:通过注解定义校验规则

  • 统一错误处理:自动生成标准错误响应

  • 多层级校验:支持DTO、Controller、Service各层

1.2 核心优势

  • 零配置启动:自动装配Validator

  • 丰富注解库:内置30+常用校验规则

  • 高度可扩展:支持自定义校验规则

  • 国际化支持:轻松实现多语言错误提示


二、快速集成与配置

2.1 添加依赖

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

2.2 基础配置

application.yml

spring:messages:basename: i18n/validation # 国际化文件路径encoding: UTF-8server:error:include-message: always # 显示具体错误信息
 

三、核心注解详解

3.1 常用校验注解

注解适用类型说明示例
@NotNull任意类型值不能为null@NotNull(message="ID必填")
@NotEmptyString/Collection非空且长度/大小>0@NotEmpty
@NotBlankString至少包含一个非空格字符@NotBlank
@Size字符串/集合长度/大小范围@Size(min=6, max=20)
@EmailString邮箱格式校验@Email
@PatternString正则表达式匹配@Pattern(regexp="^1[3-9]\\d{9}$")
@Min/@Max数值类型数值范围限制@Min(18)
@Future/@Past时间类型未来/过去时间校验@Future

3.2 嵌套对象校验

public class OrderDTO {@Valid // 启用嵌套校验private UserDTO user;@Validprivate List<@Valid ProductItem> items;
}public class UserDTO {@NotBlankprivate String name;@Emailprivate String email;
}
 

四、实战开发步骤

4.1 DTO类定义校验规则

public class UserCreateRequest {@NotBlank(message = "{user.name.required}")@Size(max = 50, message = "{user.name.length}")private String name;@Email(message = "{user.email.invalid}")private String email;@Pattern(regexp = "^(?=.*[A-Za-z])(?=.*\\d)[A-Za-z\\d]{8,}$", message = "{user.password.policy}")private String password;
}

4.2 Controller层启用校验

@PostMapping("/users")
public ResponseEntity<User> createUser(@RequestBody @Valid UserCreateRequest request) {// 业务逻辑处理return ResponseEntity.ok(userService.create(request));
}

4.3 统一异常处理

@RestControllerAdvice
public class GlobalExceptionHandler {@ExceptionHandler(MethodArgumentNotValidException.class)public ResponseEntity<ErrorResponse> handleValidationException(MethodArgumentNotValidException ex) {List<String> errors = ex.getBindingResult().getFieldErrors().stream().map(error -> error.getField() + ": " + error.getDefaultMessage()).collect(Collectors.toList());return ResponseEntity.badRequest().body(new ErrorResponse("VALIDATION_FAILED", errors));}
}
 

五、高级功能实现

5.1 自定义校验规则

步骤1:创建注解

@Target({FIELD, PARAMETER})
@Retention(RUNTIME)
@Constraint(validatedBy = PhoneNumberValidator.class)
public @interface PhoneNumber {String message() default "{validation.phone.invalid}";Class<?>[] groups() default {};Class<? extends Payload>[] payload() default {};
}

步骤2:实现校验逻辑

public class PhoneNumberValidator implements ConstraintValidator<PhoneNumber, String> {private static final Pattern PHONE_PATTERN = Pattern.compile("^1[3-9]\\d{9}$");@Overridepublic boolean isValid(String value, ConstraintValidatorContext context) {if (value == null) return true; // 允许空值,配合@NotNull使用return PHONE_PATTERN.matcher(value).matches();}
}

5.2 分组校验

public interface CreateGroup {}
public interface UpdateGroup {}public class UserDTO {@Null(groups = CreateGroup.class)@NotNull(groups = UpdateGroup.class)private Long id;@NotBlank(groups = {CreateGroup.class, UpdateGroup.class})private String name;
}@PostMapping("/users")
public ResponseEntity<?> createUser(@RequestBody @Validated(CreateGroup.class) UserDTO dto) {// 创建逻辑
}
 

六、常见问题与解决方案

6.1 校验不生效的常见原因

  1. 缺少@Valid注解:Controller方法参数前忘记添加

  2. 错误异常处理:覆盖了默认的异常处理逻辑

  3. 静态嵌套类:DTO使用static内部类导致无法实例化

  4. 字段访问权限:校验字段需要getter方法

6.2 国际化配置

messages.properties

user.name.required=用户名不能为空
user.email.invalid=邮箱格式不正确
validation.phone.invalid=手机号格式错误

validation_zh_CN.properties

javax.validation.constraints.NotNull.message=不能为null
 

七、性能优化建议

  1. 避免过度校验:只在必要层级进行校验

  2. 合理使用校验组:减少不必要的校验逻辑

  3. 缓存Validator:重复使用Validator实例

@Bean
public Validator validator() {return Validation.buildDefaultValidatorFactory().getValidator();
}
 

八、测试验证

8.1 单元测试示例

@SpringBootTest
public class UserValidationTest {@Autowiredprivate Validator validator;@Testvoid whenInvalidEmail_thenValidationFails() {UserCreateRequest request = new UserCreateRequest();request.setEmail("invalid-email");Set<ConstraintViolation<UserCreateRequest>> violations = validator.validate(request);assertThat(violations).hasSize(1);}
}

8.2 API测试(使用MockMvc)

@WebMvcTest(UserController.class)
class UserControllerTest {@Autowiredprivate MockMvc mvc;@Testvoid createUser_withInvalidPassword_returnsBadRequest() throws Exception {String json = """{"name": "test","email": "test@example.com","password": "123"}""";mvc.perform(post("/users").contentType(APPLICATION_JSON).content(json)).andExpect(status().isBadRequest()).andExpect(jsonPath("$.errors[0]").value("password: 密码必须包含字母和数字"));}
}
 

九、总结与最佳实践

  1. 分层校验原则

    • Controller层:校验输入格式

    • Service层:校验业务规则

    • DAO层:校验数据完整性

  2. 错误消息规范

    • 使用明确的错误代码

    • 保持消息内容用户友好

    • 实现多语言支持

  3. 文档化校验规则

    • 在Swagger文档中展示参数约束

    • 维护校验规则变更日志

http://www.dtcms.com/a/468600.html

相关文章:

  • 用人名做网站域名crm系统网址
  • 开不锈钢公司怎么做网站健康陕西app管理端最新版
  • 广东中国移动网站wordpress 封ip段
  • 十大金融公司排名廊坊网站快速排名优化
  • 网站建设方案书 阿里云网站页面优化签象客
  • 江苏百城建设有限公司官方网站上海做网站建设的公司排名
  • 邢台做网站建设公司哪家好?wordpress可爱的主题
  • 网上有做logo的网站吗为什么没人做物流网站
  • 北京网站建设哪里好网站开发的解决方案
  • 网站设计培训班老师西安景观设计公司排行
  • 网站建设的公司这个中国建设银行网站荆门网点查询系统
  • 新媒体营销有哪些岗位成都关键词优化
  • 一条龙搭建网站三屏营销型网站建设
  • 360建站平台wordpress备案号修改
  • 大型网站建设公司排名wordpress棋牌插件
  • wordpress主题开发时间seo关于网站
  • 做外贸 上国外网站网站上做播放器流量算谁的
  • 做VIP视频网站赚钱上海网站建设方法
  • 网站建设 项目书 框架河北省住房和城乡建设厅网站主页
  • 公司网站建设需要些什么要求设计类专业要艺考吗
  • php 可以自己做网站吗律师事务所网站建设
  • 今年的公需课在哪个网站做网站的需求
  • 河南平台网站建设制作wordpress打开加速
  • 网站源码免费资源网德州哪家网站建设好
  • 网站做不做双解析phpcms v9 网站搬家
  • 做直播券的网站有多少桂林生活网分类信息网站
  • 安国网站建设建站加盟
  • 优化网站排名方法教程宇舶手表网站
  • 电商网站充值消费系统织梦网站英文版怎么做
  • 使用 私有云 做视频网站山东省建设厅特种作业证查询网站