>백엔드 개발 >Golang >Go에서 문자열 유효성 검사 단순화: validatorgo 소개

Go에서 문자열 유효성 검사 단순화: validatorgo 소개

Linda Hamilton
Linda Hamilton원래의
2024-11-14 20:20:02534검색

Simplifying String Validation in Go: Introducing validatorgo

js 라이브러리 validator.js를 기반으로 하는 문자열 검사기 및 삭제기 라이브러리

왜 validatorgo를 선택합니까?

패키지 유효성 검사기 또는 govalidator와 같은 인기 있는 Go 라이브러리를 사용하는 것은 어떨까요? 두 라이브러리 모두 잘 알려져 있지만 validatorgo는 독립형 문자열 유효성 검사에 중점을 두고 validator.js에서 영감을 받은 광범위한 사용자 정의 가능한 유효성 검사기 컬렉션을 제공하지만 두 Go 라이브러리 모두 완전히 구현하지 않습니다.

go-playground/validator 및 govalidator와 비교하여 validatorgo가 뛰어난 점은 다음과 같습니다.


1. go-playground/validator와 비교

  • 직접 문자열 유효성 검사: go-playground/validator는 주로 태그를 사용하여 구조체 필드의 유효성을 검사하기 위해 구축되었으며, 이는 JSON 또는 구조체 기반 데이터를 처리하는 데 이상적입니다. 그러나 ValidatorGo가 구조체 태그나 추가 설정 없이 원활하게 수행하는 개별 문자열의 유효성 검사를 위해 설계되지 않았습니다.

  • 성능: go-playground/validator는 리플렉션을 사용하여 구조체 태그를 동적으로 검사합니다. 리플렉션은 강력하기는 하지만 성능 오버헤드를 초래할 수 있습니다. 특히 크거나 복잡한 데이터 구조가 검증될 때 더욱 그렇습니다. validatorgo는 반사를 방지하여 성능을 향상시켜 단일 필드 검증이 필요한 시나리오에서 더 빠르고 효율적으로 만듭니다.


2. asaskevich/govalidator와 비교

  • 맞춤화 및 유연성: govalidator는 문자열에 대한 다양한 유효성 검사기를 제공하지만 validatorgo는 개별 유효성 검사기에 특정 옵션과 구성을 허용하여 유연성을 향상합니다. 예를 들어, 날짜 형식이나 로케일 사양을 사용자 정의할 수 있으므로 개발자는 프로젝트 요구 사항에 맞는 유효성 검사 규칙을 더 효과적으로 제어할 수 있습니다.

프로젝트 동기부여

Go 웹 애플리케이션에서 HTTP 요청의 유효성을 검사하는 ginvalidator라는 다른 Go 라이브러리에 대한 종속성 역할을 하기 위해 validatorgo를 만들었습니다. Node.js 및 Express용 인기 검증 라이브러리인 express-validator에서 영감을 받은 ValidatorGo는 효율적이고 사용자 정의 가능하며 간단한 문자열 검증을 위해 Go 생태계의 공백을 메웁니다. 다른 라이브러리는 너무 과하거나 기능이 부족하거나 내 사용 사례에 맞지 않았기 때문에 실용적인 솔루션을 제공하기 위해 validatorgo를 구축했습니다.

설치

go get을 사용하세요.

 go get github.com/bube054/validatorgo

그런 다음 패키지를 자신의 코드로 가져옵니다.

 import (
   "fmt"
   "github.com/bube054/validatorgo"
 )

긴 validatorgo 패키지 이름을 사용하는 것이 마음에 들지 않으면 이렇게 할 수 있습니다.

 go get github.com/bube054/validatorgo

간단한 유효성 검사기 예

 import (
   "fmt"
   "github.com/bube054/validatorgo"
 )

일부 검증인

다음은 다양한 문자열 형식과 유형을 포괄하여 여러 유효성 검사 요구 사항에 다목적으로 사용할 수 있는 validatorgo 패키지에서 제공하는 유효성 검사기 목록입니다.

검증기 설명
포함 문자열에 지정된 하위 문자열이 포함되어 있는지 확인합니다.
같음 문자열이 비교 문자열과 정확히 동일한지 확인합니다.
IsAba라우팅 문자열이 유효한 ABA 라우팅 번호(미국 은행 계좌)인지 확인합니다.
이후 날짜 문자열이 지정된 날짜 이후인지 확인합니다.
알파 문자열에 문자(a-zA-Z)만 포함되어 있는지 확인합니다.
영숫자 문자열에 문자와 숫자만 포함되어 있는지 확인합니다.
IsAscii 문자열에 ASCII 문자만 포함되어 있는지 확인합니다.
IsBase32 문자열이 유효한 Base32 인코딩 값인지 확인합니다.
IsBase64 문자열이 Base64 인코딩인지 확인합니다.
이전 날짜가 지정된 날짜 이전인지 확인합니다.
부울 문자열이 "true"인지 "false"인지 확인합니다.
이즈크레딧카드 문자열이 유효한 신용카드 번호인지 확인합니다.
통화 문자열이 유효한 통화 형식인지 확인합니다.
날짜 문자열이 유효한 날짜인지 확인합니다.
10진수 문자열이 유효한 십진수를 나타내는지 확인합니다.
이메일 문자열이 유효한 이메일 주소 형식인지 확인합니다.
비어있음 문자열이 비어 있는지 확인합니다.
IsFQDN 문자열이 정규화된 도메인 이름인지 확인합니다.
플로트 문자열이 부동 소수점 숫자를 나타내는지 확인합니다.
IsHexColor 문자열이 유효한 16진수 색상(예: #FFFFFF)인지 확인합니다.
IsIP 문자열이 유효한 IP 주소(IPv4 또는 IPv6)인지 확인합니다.
ISO8601 문자열이 ISO8601 날짜 형식인지 확인합니다.
길이 문자열의 길이가 지정된 범위 내에 있는지 확인합니다.
IsMimeType 문자열이 유효한 MIME 유형인지 확인합니다.
IsMobilePhone 문자열이 특정 지역에 유효한 휴대폰 번호인지 확인합니다.
IsMongoID 문자열이 유효한 MongoDB ObjectID인지 확인합니다.
숫자임 문자열에 숫자만 포함되어 있는지 확인합니다.
IsPostalCode 문자열이 지정된 지역의 유효한 우편번호인지 확인합니다.
IsRFC3339 문자열이 RFC3339 날짜 형식인지 확인합니다.
이즈슬러그 문자열이 URL 친화적인지 확인합니다(문자, 숫자, 대시만 해당).
IsStrongPassword 문자열이 일반적인 비밀번호 강도 요구 사항을 충족하는지 확인합니다.
IsURL 문자열이 URL인지 확인합니다.
IsUUID 문자열이 유효한 UUID(버전 1-5)인지 확인합니다.
IsUpperCase 문자열이 모두 대문자인지 확인하세요.
VAT인가 문자열이 특정 국가에 유효한 VAT 번호인지 확인합니다.
경기 문자열이 지정된 정규 표현식과 일치하는지 확인합니다.

이 표에는 현재 validatorgo에서 사용할 수 있는 대부분의 유효성 검사기가 포함됩니다. 각 유효성 검사기의 자세한 사용법은 패키지 설명서를 참조하세요.

⚠ 주의

옵션 구조체(포인터 또는 비포인터)가 필요한 유효성 검사기를 사용하는 경우 항상 모든 구조체 필드에 대한 값을 명시적으로 제공하세요.
누락된 필드가 자동으로 기본값으로 설정되는 validator.js와 달리 Go는 엄격한 유형을 사용합니다.
즉, 누락된 값은 부울의 경우 기본적으로 false, 숫자 유형의 경우 0 등으로 설정됩니다.
JavaScript 버전에 익숙하다면 모든 필드를 지정하지 않으면 예기치 않은 동작이 발생할 수 있습니다.


 go get github.com/bube054/validatorgo

간단한 살균제 예

 import (
   "fmt"
   "github.com/bube054/validatorgo"
 )

살균제

Sanitizer Description
Trim Removes whitespace from both ends of the string.
LTrim Removes whitespace from the left side of the string.
RTrim Removes whitespace from the right side of the string.
ToLower Converts the entire string to lowercase.
ToUpper Converts the entire string to uppercase.
Escape Escapes HTML characters in the string to prevent injection attacks.
Unescape Reverts escaped HTML characters back to normal characters.
NormalizeEmail Standardizes an email address, e.g., removing dots in Gmail addresses.
Blacklist Removes characters from the string that match specified characters or patterns.
Whitelist Retains only characters in the string that match specified characters or patterns.
Replace Replaces occurrences of a substring with a specified replacement.
StripLow Removes control characters, optionally allowing some specified ones.
TrimSpace Trims all types of whitespace from both ends of the string.
ToBoolean Converts common truthy and falsy values in strings into boolean true or false.
ToInt Converts a numeric string into an integer, if possible.
ToFloat Converts a numeric string into a floating-point number, if possible.

이러한 새니타이저는 잠재적으로 원치 않거나 위험한 문자를 제거하거나 수정하여 데이터 일관성과 보안을 보장하는 데 자주 사용됩니다.

각 살균제의 구체적인 구현과 예는 공식 validatorgo 문서를 참조하세요.

요약

validatorgo는 다음이 필요한 경우 이상적인 선택입니다.

  • 구조체 기반 리플렉션과 관련된 성능 비용 없이 개별 필드에 대한 효율적이고 리플렉션 없는 검증
  • 고도로 맞춤설정 가능한 유효성 검사 옵션은 최신 데이터 형식에 맞춰 validator.js와 동일한 견고성을 제공합니다.

validatorgo를 사용하면 Go의 독립 실행형 및 웹 애플리케이션 요구 사항을 모두 지원하는 문자열 검증을 위해 특별히 설계된 도구를 얻을 수 있습니다.

유지관리자

  • bube054 - Attah Gbubemi David (저자)

위 내용은 Go에서 문자열 유효성 검사 단순화: validatorgo 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.