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,但我认为这与问题无关
例如,您应该将@email和 的注释更改@Pattern为@field:Email和。@field:Pattern
这样做的原因有两个,一方面,您将注释放在 Kotlin 属性上,并且可以通过多种方式访问 Kotlin 属性。因此,您需要指定如何访问要应用注释的属性。另一方面,注释有一组预定义的目标。您可以检查注释以查看例如它是否具有字段目标。这就是为什么我们可以使用@field:Pattern和@field:Email。
这是与 java 的一个关键区别,在 java 中,您有不同的 getter、setter 和字段等。
| 归档时间: |
|
| 查看次数: |
1798 次 |
| 最近记录: |