연습
[Typescript]: express의 req.user 붙이기
onaeonae1
2021. 5. 28. 17:59
들어가는 글
Typescript를 쓰기 전에 그냥 node+express에서는 JWT로 사용자 인증을 하고 해당 정보를 전달할 때
req.user = decoed_user 와 같은 식으로 처리를 해주었다.
그런데 이게 TypeScript에서는 막힌다.
설명
왜냐하면 express.Request에 "user" namespace가 없기 때문이다.
이를 추가해주려면 다음의 과정이 필요하다.
1. decoded_user interface를 정의
-> 폴더 하나 파고 type 정의 후 export
2. express.Request 변경에 추가
-> 사진 참고
3. tsconfig 설정
-> typeRoots 설정
아니 이 간단한 걸 왜 못하고 시간을 날렸나?
mongoose model과 JWT로 decode된 user를 착각했기 때문이다.
위의 사진을 보면 뭔가 이상함을 느낄 수 있다.
JWT를 사용할 때는 당연히 user 정보를 모두 가지고 있지는 않는다. 특히 password를 들고 다니는건 바보짓이다.(encrypted 라고 해도)
그래서 어느정도 노출이 되도 큰 문제가 없는 데이터(userName 같은)들을 가지고 sign, verify를 한다.
그런데 나는 mongoose의 user model을 넣으려고 하다보니깐 req.user가 추가에 성공했어도 타입 문제가 결국 발생함.