Kotlin spring boot @RequestBody 验证未触发

art*_*ian 4 spring kotlin spring-boot spring-validation

我在使用验证 @RequestBody 的项目上遇到问题

implementation("org.springframework.boot:spring-boot-starter-validation")
Run Code Online (Sandbox Code Playgroud)

我的 DTO 如下所示:

import javax.validation.constraints.Email
import javax.validation.constraints.Pattern

class LoginDto(
    @Email
    val email: String,

    @Pattern(regexp = Constants.PASSWORD_REGEX)
    val password: String
)
Run Code Online (Sandbox Code Playgroud)

控制器看起来像这样:

import org.springframework.validation.annotation.Validated
import org.springframework.web.bind.annotation.PostMapping
import org.springframework.web.bind.annotation.RequestBody
import org.springframework.web.bind.annotation.RestController
import javax.validation.Valid

@RestController
@Validated
class AuthController(private val authService: AuthService) {

    @PostMapping("login")
    fun login(@Valid @RequestBody loginDto: LoginDto): LoginResponse {
        return authService.login(loginDto)
    }
    ...
}
Run Code Online (Sandbox Code Playgroud)

如果我尝试传递无效数据,验证不会出现错误:

{
    "password":"hello",
    "email":"dfdfdfdf"
}
Run Code Online (Sandbox Code Playgroud)

我没有收到错误,我使用 Exposed 而不是 jpa,但我认为这与问题无关

Dan*_*cob 6

例如,您应该将@email和 的注释更改@Pattern@field:Email和。@field:Pattern

这样做的原因有两个,一方面,您将注释放在 Kotlin 属性上,并且可以通过多种方式访问​​ Kotlin 属性。因此,您需要指定如何访问要应用注释的属性。另一方面,注释有一组预定义的目标。您可以检查注释以查看例如它是否具有字段目标。这就是为什么我们可以使用@field:Pattern@field:Email

这是与 java 的一个关键区别,在 java 中,您有不同的 getter、setter 和字段等。