springboot 关于controller层传递单个参数的校验

本文介绍如何在SpringBoot项目中实现控制器层的参数校验,包括引入依赖、配置验证器、异常处理等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关于springboot项目中,controller层对传递对象的校验,可以参照该文进行查看, 点击打开链接http://www.cnblogs.com/myinspire/articles/7649027.html

本文主要针对controller层中,对于单个参数的校验:

1、引入依赖

<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-validator</artifactId>
    <version>5.3.1.Final</version>
</dependency>

2、首先,需要我们声明一个Bean,注入校验器到Spring Boot的运行环境,负责不能生效对应的@Range@Min@Maxvalidator包里面提供的注解

@Configuration
@EnableAutoConfiguration
public class ValidatorConfig {
   @Bean
   public MethodValidationPostProcessor methodValidationPostProcessor(){
      return new MethodValidationPostProcessor();
   }
}

3、controller层

特别注意:

1、@Validated要在controller上标注

@Api(value = "type", description = "辅导类型")
@RestController
@Validated
@RequestMapping(value = "type")
public class CompositionTypesController extends BaseController {
   @ApiOperation(value="新增辅导类型", notes="新增辅导类型")
   @LoginRequired
   @PostMapping(value = "addCompostionTyp1e")
   public Response addCompostionTyp1e(@ApiParam(value = "成绩") @Max(value = 60,message = "得分必须小于60") @RequestParam int score, @ApiParam(value = "年龄") @Min(value = 3, message = "年龄大于3") @RequestParam int age, @ApiParam(value = "辅导作文类型") @NotNull(message = "辅导作文类型不能为空") @RequestParam(required = false) String name){
      //校验
      logger.info(String.valueOf(age));
      return success(ResponseCode.OK);
   }
}

4、统一异常捕获

@ControllerAdvice
public class ExceptionAdvice {
   /**
    * 拦截捕捉自定义异常 ConstraintViolationException.class
    * @param ex
    * @return
    */
   @ResponseBody
   @ExceptionHandler(value = ConstraintViolationException.class)
   public Map ConstraintViolationExceptionHandler(ConstraintViolationException ex) {
      Map map = new HashMap();
      Set<ConstraintViolation<?>> constraintViolations = ex.getConstraintViolations();
      Iterator<ConstraintViolation<?>> iterator = constraintViolations.iterator();
      List<String> msgList = new ArrayList<>();
      while (iterator.hasNext()) {
         ConstraintViolation<?> cvl = iterator.next();
         msgList.add(cvl.getMessageTemplate());
      }
      map.put("status", ExceptionCode.CVL_EXCEPTION);
      map.put("msg", msgList);
      return map;
   }
}

5、在swagger中进行接口调试




注:

校验常用的注解如下:

@AssertFalse 校验false
@AssertTrue 校验true
@DecimalMax(value=,inclusive=) 小于等于value,
inclusive=true,是小于等于
@DecimalMin(value=,inclusive=) 与上类似
@Max(value=) 小于等于value
@Min(value=) 大于等于value
@NotNull  检查Null
@Past  检查日期
@Pattern(regex=,flag=)  正则
@Size(min=, max=)  字符串,集合,map限制大小
@Valid 对po实体类进行校验

@NotNull 和 @NotEmpty  和@NotBlank 区别

 @NotEmpty 用在集合类上面

@NotBlank 用在String上面

@NotNull    用在基本类型上


<think>好的,我现在需要回答用户关于Spring Boot多模块项目中Controller模块需要什么依赖的问题。用户还特别提到了是否使用spring-boot-starter-web。 首先,我得回忆一下Spring Boot的基本依赖结构。用户之前的问题是关于Maven多模块的,现在转向了Spring Boot多模块,所以可能需要结合两者。在Spring Boot项目中,模块划分通常包括controller、service、repository等。每个模块的依赖需要正确配置,以避免重复或遗漏。 用户问controller模块是否需要依赖spring-boot-starter-web。我记得spring-boot-starter-web是Spring MVC的核心依赖,包含了Tomcat和Spring Web MVC等,所以应该是必须的。但需要确认是否在父模块中已经引入,或者是否每个子模块需要单独声明。 接下来,考虑到多模块项目结构,父模块通常管理公共依赖和插件,子模块继承父模块的配置。如果父pom已经声明了spring-boot-starter-web,子模块可能需要显式引用,或者通过依赖管理传递。但通常,每个模块应该声明自己需要的依赖,即使父模块有版本管理。 另外,controller模块可能还需要依赖service模块,因为它会调用service的接口。这时候,在controller模块的pom.xml中需要添加对service模块的依赖。例如,如果项目结构是父模块包含子模块如api、service、controller等,那么controller模块的依赖应该包括service模块和spring-boot-starter-web。 还需要注意,如果使用了Spring Boot的自动配置,确保相关依赖正确引入。比如,spring-boot-starter-web默认包含Jackson用于JSON处理,但如果需要其他功能如Thymeleaf模板引擎,可能需要额外依赖。 此外,是否需要其他依赖,比如Spring Security或者验证相关的starter,如spring-boot-starter-validation,这取决于项目需求。如果controller需要进行参数验证,那么需要引入validation starter。 还有可能涉及到的依赖是spring-boot-starter-test,但通常在测试模块中引入,或者父模块统一管理。但用户的问题是关于controller模块本身的运行时依赖,所以可能不需要测试依赖。 总结一下,controller模块需要的主要依赖是spring-boot-starter-web,以及项目内部的其他模块如service或api。此外,根据具体功能可能需要添加验证、安全等依赖。需要确保这些依赖在pom.xml中正确声明,并且版本由父模块统一管理以避免冲突。 现在需要检查是否有遗漏的部分,比如是否需要在controller模块中引入其他与Web相关的库,或者是否需要排除某些默认依赖(比如Tomcat而使用Jetty)。但用户的问题比较基础,可能不需要涉及这些高级配置,只需明确回答基本依赖即可。 可能还需要提醒用户关于多模块项目中模块之间的依赖关系,例如controller依赖service,service依赖dao等,以及如何正确地在pom.xml中引用这些子模块。同时,需要确保spring-boot-starter-web被正确引入,以启用Spring MVC的功能,如处理HTTP请求、使用@RestController等注解。 最后,是否需要给出一个示例的pom.xml片段,展示controller模块的依赖配置,这样用户能更直观地理解。</think>在Spring Boot多模块项目中,Controller模块的依赖配置需要重点关注以下三个面: --- ### **一、核心依赖配置(Controller模块pom.xml)** ```xml <!-- 必须显式声明Web依赖 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- 依赖项目内部的Service模块 --> <dependency> <groupId>com.yourcompany</groupId> <artifactId>your-service-module</artifactId> <version>${project.version}</version> </dependency> ``` #### **关键说明**: 1. `spring-boot-starter-web` 是**必要依赖**,包含: - 嵌入式Tomcat(默认容器) - Spring MVC核心组件 - Jackson JSON处理器 - 自动配置支持 2. 即使父pom已声明版本号,子模块仍需显式声明依赖(父子关系只管理版本,不自动传递依赖) --- ### **二、进阶依赖场景** ```xml <!-- 参数校验支持 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId> </dependency> <!-- 接口文档生成 --> <dependency> <groupId>org.springdoc</groupId> <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId> <version>2.1.0</version> </dependency> <!-- 安全控制 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId> </dependency> ``` #### **使用场景**: - 当需要`@Valid`注解进行参数校验时添加validation - 需要生成OpenAPI/Swagger文档时添加springdoc - 需要接口鉴权时添加security --- ### **三、典型依赖关系图** ```mermaid graph TD parent[Parent POM] --> controller parent --> service parent --> dao controller --> service controller --> spring-boot-starter-web service --> dao service --> spring-boot-starter-data-jpa classDef important fill:#f9f,stroke:#333; class controller important ``` --- ### **四、常见问题排查** 1. **No qualifying bean错误** 检查是否在启动类添加包扫描: ```java @SpringBootApplication(scanBasePackages = { "com.yourcompany.controller", "com.yourcompany.service" }) ``` 2. **404找不到接口** 确认是否缺少Servlet组件: ```xml <!-- 使用JSP时需要额外添加 --> <dependency> <groupId>org.apache.tomcat.embed</groupId> <artifactId>tomcat-embed-jasper</artifactId> </dependency> ``` 3. **依赖冲突解决** 使用`mvn dependency:tree`查看依赖树,排除冲突包: ```xml <exclusions> <exclusion> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> </exclusion> </exclusions> ``` --- ### **五、最佳实践建议** 1. **分控制** 在父模块中统一管理版本号: ```xml <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>3.1.5</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> ``` 2. **瘦Controller原则** Controller应保持简洁,典型结构: ```java @RestController @RequiredArgsConstructor // Lombok自动注入 public class UserController { private final UserService userService; @Operation(summary = "获取用户详情") // OpenAPI注解 @GetMapping("/users/{id}") public ResponseEntity<UserDTO> getUser( @PathVariable @Min(1000) Long id) { // 参数校验 return ResponseEntity.ok(userService.getById(id)); } } ``` 3. **监控增强** 添加健康检查端点: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> ``` --- **架构演进提示**:当Controller出现以下症状时,建议进行模块拆分: - 单个Controller类超过800行代码 - 同时处理Web请求和RPC请求 - 需要为不同客户端(APP/H5/小程序)提供差异化响应 可考虑拆分为: ``` web-module ├── web-admin // 管理端接口 ├── web-app // 移动端接口 └── web-thirdparty // 第三方对接接口 ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值