js 라이브러리 validator.js를 기반으로 하는 문자열 검사기 및 삭제기 라이브러리
패키지 유효성 검사기 또는 govalidator와 같은 인기 있는 Go 라이브러리를 사용하는 것은 어떨까요? 두 라이브러리 모두 잘 알려져 있지만 validatorgo는 독립형 문자열 유효성 검사에 중점을 두고 validator.js에서 영감을 받은 광범위한 사용자 정의 가능한 유효성 검사기 컬렉션을 제공하지만 두 Go 라이브러리 모두 완전히 구현하지 않습니다.
go-playground/validator 및 govalidator와 비교하여 validatorgo가 뛰어난 점은 다음과 같습니다.
직접 문자열 유효성 검사: go-playground/validator는 주로 태그를 사용하여 구조체 필드의 유효성을 검사하기 위해 구축되었으며, 이는 JSON 또는 구조체 기반 데이터를 처리하는 데 이상적입니다. 그러나 ValidatorGo가 구조체 태그나 추가 설정 없이 원활하게 수행하는 개별 문자열의 유효성 검사를 위해 설계되지 않았습니다.
성능: go-playground/validator는 리플렉션을 사용하여 구조체 태그를 동적으로 검사합니다. 리플렉션은 강력하기는 하지만 성능 오버헤드를 초래할 수 있습니다. 특히 크거나 복잡한 데이터 구조가 검증될 때 더욱 그렇습니다. 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는 다음이 필요한 경우 이상적인 선택입니다.
validatorgo를 사용하면 Go의 독립 실행형 및 웹 애플리케이션 요구 사항을 모두 지원하는 문자열 검증을 위해 특별히 설계된 도구를 얻을 수 있습니다.
위 내용은 Go에서 문자열 유효성 검사 단순화: validatorgo 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!