기억 휘발 방지소

[Node.js] express-validator로 유효성 검증하기 본문

Web/Node.js

[Node.js] express-validator로 유효성 검증하기

choice91 2021. 10. 16. 22:10
728x90
반응형

📌 express-validator

express-validator는 express 유효성 검증 모듈이다.

 

📌 설치

npm i express-validator

 

📌 유효성 검증하기

라우터에 추가해주면 된다.

'body("필드", "메시지").검증API.검증API.검증API...'의 형태로 사용하면 된다.

body는 req.body에서 오는 값만을 검사한다.

점(.)으로 검증API들을 붙여서 사용하면 된다.

const { body } = require("express-validator/check");

const { createPost } = require("../controllers/feedController");

router.post(
  "/posts",
  [
    body("title").trim().isLength({ min: 5 }),
    body("content").trim().isLength({ min: 5 }),
  ],
  createPost
);

 

📌 validationResult() 검증결과

유효성 검증을 하면서 생기는 에러메시지는 validationResult(req)로 받을 수 있다.

isEmpty()는 validationResult(req) 개체에 오류가 전혀 없는지 여부를 나타내는 boolean값을 반환한다.

const { validationResult } = require("express-validator/check");

exports.createPost = async (req, res, next) => {
  const errors = validationResult(req);
  if (!errors.isEmpty()) {
    const error = new Error("Validation fail, entered data is incorrect.");
    error.statusCode = 422;
    throw error;
  }
  // ...
}

에러 메시지가 있다면 throw error을 해준다.

 

에러를 콘솔에 찍어보면

const { validationResult } = require("express-validator/check");

exports.createPost = async (req, res, next) => {
  const errors = validationResult(req);
  console.log(errors);
  // ...
}

유효성 검증을 통과하지 못했다면 validationResult(req)는 아래와 같다.

 

Result {
  formatter: [Function: formatter],
  errors: [
    {
      value: 'test6',
      msg: 'Invalid value',
      param: 'title',
      location: 'body'
    }
  ]
}

유효성 검증을 통과했다면 아래처럼 나온다.

Result { formatter: [Function: formatter], errors: [] }

 

📌 express-validator 함수들

  • trim(): 공백을 제거한다.
  • isLength(): 문자열의 길이를 확인한다. { min: ?, max: ? }으로 최소, 최대값을 지정해 줄 수 있다. {min:0, max: undefined}이 기본값이다.
  • isEmail(): 문자열이 이메일형태인지 확인한다.
  • bail(): 이전 유효성 검사 중 하나라도 실패한 경우 유효성 검사 실행을 중지합니다. 
  • isEmpty(): 문자열의 길이가 0인지 확인한다.
  • custom(value, { req, location, path }): 사용자 정의 유효성 검사기이다. 검증 중인 필드의 값과 명시적 요청, 위치 및 필드 경로를 수신한다.

더 다양하고 자세하게 확인하려면 validator.jsexpress-validator.github.io에서 확인할 수 있다.

728x90
반응형