티스토리 뷰

들어가는 글

Typescript를 쓰기 전에 그냥 node+express에서는 JWT로 사용자 인증을 하고 해당 정보를 전달할 때

req.user = decoed_user 와 같은 식으로 처리를 해주었다.

그런데 이게 TypeScript에서는 막힌다.

 

설명

왜냐하면 express.Request에 "user" namespace가 없기 때문이다.

 

이를 추가해주려면 다음의 과정이 필요하다.

1. decoded_user interface를 정의

 -> 폴더 하나 파고 type 정의 후 export

2. express.Request 변경에 추가

 -> 사진 참고

import 후 interface Request에 user 추가

3. tsconfig 설정

 -> typeRoots 설정

./src/customTypes라고 여기에 정의해뒀다.

 

아니 이 간단한 걸 왜 못하고 시간을 날렸나?

mongoose model과 JWT로 decode된 user를 착각했기 때문이다.

위의 사진을 보면 뭔가 이상함을 느낄 수 있다.

JWT를 사용할 때는 당연히 user 정보를 모두 가지고 있지는 않는다. 특히 password를 들고 다니는건 바보짓이다.(encrypted 라고 해도)

그래서 어느정도 노출이 되도 큰 문제가 없는 데이터(userName 같은)들을 가지고 sign, verify를 한다.

 

그런데 나는 mongoose의 user model을 넣으려고 하다보니깐 req.user가 추가에 성공했어도 타입 문제가 결국 발생함.

 

 

'연습' 카테고리의 다른 글

[Python] seleniumwire 소개  (5) 2021.07.16
[Python]: black + prettier를 사용한 format시 settings.json  (0) 2021.06.02
[Typescript] nodemon 설정하기  (0) 2021.05.27
[Python] cli에서 '.' 넘기기  (0) 2021.05.20
내맘대로 정리한 XXE  (0) 2021.05.17
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/04   »
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
글 보관함