250x250
Notice
Recent Posts
Recent Comments
- Today
- Total
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- moment
- RDS
- clipBehavior
- TailwindCSS
- EC2
- mongoose
- AWS
- MYSQL
- flutter
- atlas
- Express
- nginx
- mongodb
- TypeScript
- single quote
- Find
- css
- double quote
- https
- til
- sequelize
- await
- Nodejs
- Node.js
- findByIdAndDelete
- jsonwebtoken
- JavaScript
- certbot
- async
- wil
Link
Archives
기억 휘발 방지소
[Node.js] express-validator로 유효성 검증하기 본문
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.js와 express-validator.github.io에서 확인할 수 있다.
728x90
반응형
'Web > Node.js' 카테고리의 다른 글
[Node.js] Puppeteer로 크롤링하기 (0) | 2021.10.29 |
---|---|
[Node.js] Nodemailer로 이메일 전송하기 with Gmail (1) | 2021.10.19 |
[Node.js] jsonwebtoken (0) | 2021.10.12 |
[Node.js / Sequelize] created_at, updated_at 시간을 한국시간대로 표기하기 (0) | 2021.10.07 |
[Node.js] multer (0) | 2021.09.27 |