구조체 태그로 유효성 검사 오류 메시지 사용자 정의
Gin을 사용한 Go 웹 개발에서 구조 유효성 검사는 지속성 이전에 데이터 무결성을 보장하는 데 중요한 역할을 합니다. . 그러나 기본 유효성 검사 라이브러리에서 제공되는 기본 오류 메시지는 장황하고 사용자 친화적이지 않을 수 있습니다. 이 문서에서는 개발자가 사용자에게 보다 의미 있고 실행 가능한 피드백을 제공할 수 있도록 구조체 태그를 기반으로 사용자 정의 오류 메시지를 반환하는 방법을 살펴봅니다.
Validator.ValidationErrors 이해
Gin 활용 유효성 검사를 위한 github.com/go-playground/validator/v10 라이브러리. 유효성 검사가 실패하면 validator.ValidationErrors 유형의 오류가 반환됩니다. 이 오류 유형에는 각각 잘못된 필드를 나타내는 validator.FieldError 인스턴스 조각이 포함되어 있습니다.
오류 메시지 사용자 정의
오류 메시지를 사용자 정의하려면 유효성 검사기를 풀면 됩니다. 오류 패키지를 사용하여 ValidationErrors 오류를 확인하고, validator.FieldError에 액세스하고, 필드의 태그를 기반으로 사용자 정의 오류 메시지를 구성합니다. 구조체 필드의 태그 속성을 사용하면 개발자가 사용자 지정 유효성 검사 규칙과 오류 메시지를 지정할 수 있습니다.
예를 들어 다음 코드 조각을 고려하세요.
type ApiError struct { Field string Msg string } func msgForTag(tag string) string { switch tag { case "required": return "This field is required" case "email": return "Invalid email" } return "" }
이 코드는 ApiError 구조체와 도우미를 정의합니다. 태그를 사용자 정의 오류 메시지에 매핑하는 msgForTag 함수입니다. 이를 사용하여 다음 핸들러를 구현할 수 있습니다.
var u User err := c.BindQuery(&u); if err != nil { var ve validator.ValidationErrors if errors.As(err, &ve) { out := make([]ApiError, len(ve)) for i, fe := range ve { out[i] = ApiError{fe.Field(), msgForTag(fe.Tag())} } c.JSON(http.StatusBadRequest, gin.H{"errors": out}) } return }
이 핸들러에서 validator.ValidationErrors 오류는 래핑 해제되고 각 validator.FieldError는 필드 태그를 기반으로 하는 사용자 정의 메시지와 함께 ApiError로 변환됩니다. . 그런 다음 ApiError 조각이 JSON으로 인코딩되고 필드에 해당하는 동적 키가 있는 오류 응답으로 반환됩니다.
결론
구조체 태그를 사용하여 유효성 검사 오류 메시지를 사용자 정의합니다. , 개발자는 데이터 검증 중에 보다 사용자 친화적이고 유익한 피드백을 제공할 수 있습니다. 이 접근 방식은 사용자 경험을 향상시키고 디버깅 프로세스를 단순화하여 입력 오류를 더 쉽게 식별하고 수정할 수 있게 해줍니다.
위 내용은 Go에서 구조체 태그를 사용하여 유효성 검사 오류 메시지를 사용자 정의하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!