본문 바로가기

node.js5

[Node.js] Nest.js에서 프로젝트 시작하기 0. 개요 [ 왜 Nest.js 인가 ] 이전 프로젝트에서는 Node.js에 express 프레임워크를 사용해서 개발을 해왔다. 하지만 express가 불편하다는 생각을 가지고 있었다. 명확하게 정해져 있는 구조가 없다보니 개발자마다 폴더 구조 등이 자유로웠고 가끔은 이런 것들이 꼬이기도 했다. (그리고 나는 프로젝트 문서화를 중요하게 생각하는데 Express에서는 하나하나 yaml 파일로 작성하고 있었다. 물론 express에서도 좀 더 자동화할 수 있지만 nest에서는 좀 더 간편하게 swagger 문서를 자동으로 달 수 있었다.) ( 참고 ) express에서 nest.js처럼 사용할 수 있는 방법도 있다. expresss 서버 구조 : https://jhyeok.com/node-backend-st.. 2022. 9. 14.
TypeScript + Node.js + Express 에서 프로젝트 시작하기 0. 프로젝트 폴더 생성 나의 프로젝트 폴더 구조는 다음과 같다. 1. 패키치 설치 나는 package manager로 yarn을 사용했다. 내 프로젝트 폴더 구조 기준으로 back 폴더에서 다음 명령어를 실행했다. 1) yarn 초기화 $ yarn init 2) 필요한 패키치 설치 typescript 전역으로 설치 yarn add typescript -g $ yarn add ts-node nodemon typescript @types/express @types/node nodemon --dev $ yarn add express typescript는 node에서 바로 실행되지 않기 때문에 tsc를 사용해서 javascript로 변환한 다음 실행된다. 프로덕션 환경에 올리기 위해서는 모든 파일.. 2022. 6. 6.
[Node.js] mongoose에서 새로운 필드 추가하기 01. 개요 DB 구축을 완료한 후 스키마에 새로운 필드가 추가되는 경우가 있다. 우리 서비스에서는 좋아요 수를 스키마에 추가하게 되었고 default 값으로 0이 들어가 있길 바랐다. 기존 데이터에 추가해 새로운 데이터와 동기화하기 위해서 다음과 같은 방법을 사용했다. 02. updateMany static update = async () => { const findCocktail = await Cocktail.updateMany({}, { $set: { likes: 0 } }); return findCocktail; }; updateMany를 활용하여 전체 도큐먼트에 값을 수정해보자! 👉 Mongoose 공식문서 1. 첫번 째 인자 조회 조건문이다. 나는 모든 도큐먼트를 조회할 예정임으로 {} 비우뒀.. 2022. 5. 1.
[Node.js] Validation 라이브러리, Joi로 단단한 코드짜기 01. 개요 1차 프로젝트에서는 request로 들어오는 데이터를 '@sindresorhus/is' 라이브러리를 사용해서 req.body가 비어있는지 여부만 확인했다. 하지만 좀 더 강하게 validation을 하려면 타입이 맞게 들어왔는지, 올바른 칼럼이 들어왔는지 등을 확인해야 한다. 그래서 이번엔 Joi를 사용해서 Validation 해보려 한다. ✔️ 1차 프로젝트 GitHub Repository 👉 @sindresorhus/is 문서 02. Joi 라이브러리 코드 구현 👉 Joi npm 문서 👉 Joi API 문서 외부에서 들어오는 입력을 항상 validation 하는 습관은 중요하다고 한다. Joi에 대한 자료가 많지 않아 문서를 참고해서 구현해보자. 현재 라우터, 서비스 로직, 디비, 미들웨.. 2022. 4. 28.
[Node.js+Express] Refresh Token 구현 01. 개요 ✔️ GitHub Repository 1차 프로젝트로 포트폴리오 공유 웹서비스를 개발했다. 당시 개발 일정이 2주로 한정되어 있었고 시간이 부족해서 Access Token만을 이용한 인증 방식으로 개발을 했다. 개발 과정에서도 팀원끼리 한번 발급받은 Token으로 유효기간이 만료되기 전까지팀원 전체가 돌아가면서 사용했다.이때 들었던 생각은 만약에 제 3자가 유효기간이 만료되기 전 Token을 탈취해서 사용하게 된다면우리 서비스는 보안이 좋다고 할 수 있을까? 우리 서비스의 사용자가 안심하고 서비스를 이용할 수 있을까? 라는 고민이 들었다. 그래서 현재 진행하고 있는 2차 프로젝트에는 Refresh Token을 구현하려고 한다. + 왜 JWT 토큰을 사용할까? Stateful 해야하는 세션의 .. 2022. 4. 25.
반응형