首页 > 解决方案 > 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()
    }

难道我做错了什么?

标签: javaspring-bootkotlinannotationsconstraints

解决方案


来自@JBNizet 评论

@Min(value= 5)(当然还有其他验证注释)替换为@field:Min(value= 5).


推荐阅读