java - javax.validation.constraints 中的注释不起作用(忽略)
问题描述
我正在尝试使用 javax 约束在运行逻辑之前预先验证请求内容。
我已经尝试了任何可能的解决方案,但仍然无法将 javax 注释在 Spring 引导中工作。
import javax.validation.constraints.Min
import javax.validation.constraints.Pattern
data class LoginRequest (
@Credential //Custom constraint that works just fine
val credential: String,
@Min(value= 5)
val password: String,
@Pattern(regexp = Constants.Regex.DEVICE_ID_REGEX, message = "Invalid device ID")
val device: String
): Serializable
这是 pom.xml 的一部分
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
.
.
<dependency>
<groupId>javax.validation</groupId>
<artifactId>validation-api</artifactId>
<version>2.0.1.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate.validator</groupId>
<artifactId>hibernate-validator</artifactId>
<version>6.0.17.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate.validator</groupId>
<artifactId>hibernate-validator-annotation-processor</artifactId>
<version>6.0.17.Final</version>
</dependency>
这是控制器
import javax.validation.Valid
@PostMapping("/login")
fun userLoginEndpoint(@Valid @RequestBody loginRequest: LoginRequest): ResponseEntity<User> {
return authService.loginUser(loginRequest)
?.let{ ResponseEntity(it, HttpStatus.ACCEPTED)}
?: ResponseEntity.status(HttpStatus.UNAUTHORIZED).build()
}
难道我做错了什么?
解决方案
来自@JBNizet 评论
将@Min(value= 5)
(当然还有其他验证注释)替换为@field:Min(value= 5)
.
推荐阅读
- python - 计算 FileResponse 对象内容的 SHA256 哈希
- python - 在 Python 中使用条件元组对数据进行子集化
- c# - 在 TreeView 中的绑定集合中向上/向下移动项目重复项
- c# - 声明转换期间调用 API
- blueprism - 如何更改 Blue Prism Collection 中的列名?
- rest - DTO 应该代表嵌套的实体结构,还是应该将我的路径设置为每个嵌套对象都有一个端点?
- google-cloud-platform - GCP Terraform 以公共地址为条件
- swift - 如何检查在我的单元测试中是否释放了无主引用?
- r - 如何在 R Shiny 应用程序中显示特定 R 文件的代码?
- javascript - 我如何在 JS 中设置 coockies,使输入字段中的值过期?