>웹 프론트엔드 >JS 튜토리얼 >Zod를 사용하여 환경 변수 검증

Zod를 사용하여 환경 변수 검증

WBOY
WBOY원래의
2024-08-16 12:40:06921검색

Validate your environment variables with Zod

Zod는 TypeScript 생태계에서 가장 유명한 검증 라이브러리입니다. Zod를 사용하면 스키마를 생성하고 스키마에 따라 데이터의 유효성을 검사할 수 있습니다. 아래 스키마를 관찰하세요.

import { z } from 'zod'

const UserSchema = z.object({
  name: z.string().min(1),
  age: z.number({ coerce: true }).min(18),
  email: z.string().email(),
})

이 스키마는 다음과 같이 개체의 유효성을 검사하는 데 사용할 수 있습니다.

const data = {
  name: 'John Doe',
  age: 18,
  email: 'john@example.com',
}

// If there is a validation error, it throws an error
const validatedData = UserSchema.parse(data)

// If there is a validation error, it returns an error object for you to handle later
const safeValidatedData = UserSchema.safeParse(data)
// => { success: false; error: ZodError }
// => { success: true; data: 'billie' }

Zod는 데이터에 대해 다양한 유형의 유효성 검사를 수행할 수 있으므로 자세한 내용은 설명서를 읽어보세요.

환경 변수 검증

Zod를 사용하여 process.env에 있는 값의 유효성을 검사하고 애플리케이션에서 환경 변수를 사용하기 전에 이를 처리할 수도 있습니다. 일반적으로 저는 아래 예와 같이 Environment.ts 파일을 생성하는 것을 좋아합니다.

import { z } from 'zod'

const environmentSchema = z.object({
  // Define the possible values for NODE_ENV, always leaving a default value:
  NODE_ENV: z.enum(['test', 'development', 'production']).default('production'),
  // Environment variables are always defined as strings. Here, convert the string to a number and set a default value:
  PORT: z.number({ coerce: true }).default(3000),
})

export const env = environmentSchema.parse(process.env)

그런 다음 변수를 가져와서 애플리케이션 전체에서 사용하세요.

import Fastify from 'fastify'
import { env } from './environment.js'

const app = Fastify({ logger: true })
app.listen({ port: env.PORT }, (err) => {
  if (err) {
    app.log.error(err)
    process.exit(1)
  }
})

위 내용은 Zod를 사용하여 환경 변수 검증의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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