포시코딩

1월2일 본문

TIL

1월2일

포시 2023. 1. 2. 17:11
728x90

middleware를 통한 유저 정보 전달

로그인한 유저의 데이터를 다른 기능에서 가져와 써야할 때

어디서 어떤 값을 가져와 어떻게 사용해야 할지 헤매고 있었다.

 

로그인한 여부는 request.cookies에 담긴 accessToken, refreshToken을 통해 알 수 있었는데

middleware를 통해 확인 과정을 거쳐 accessToken에 담긴 user의 id(PK)를 받을 수 있었다.

 

여러 방법이 있을테지만

구한 userId로 user 정보를 DB에서 받아와 통째로 res.locals에 넣는 방법을 택했다.

 

authMiddleware.js

module.exports = async (req, res, next) => {

  // ...생략

  const userId = TokenManager.getAccessTokenPayload(accessToken).userId;
  
  const userInfo = await usersService.findUserById(userId);
  res.locals.userInfo = userInfo;
  next();
};

res.locals.userInfo = userInfo를 통해 유저 정보를 넣고나선 아래와 같이 활용이 가능하다.

 

orders.routes.js

const express = require('express');
const router = express.Router();

const OrdersController = require('../controllers/orders.controller');
const ordersController = new OrdersController();
const authMiddleware = require('../config/authMiddleware');

router.post('/orders', authMiddleware, ordersController.createOrder);

module.exports = router;

ordersController.js

// ...생략

const userInfo = res.locals.userInfo;

const id = userInfo.id;
const name = userInfo.name;

 

ejs와 같이 응용한다면 다음과 같이도 사용할 수 있다.

 

routes/index.js

class UsersController {

  // ...생략

  router.use('/', authMiddleware, (req, res) => {
    if (res.locals.userInfo) {
      const userInfo = res.locals.userInfo;
      res.render('index', { userInfo: { name: userInfo.name, point: userInfo.point } });
    } else {
      res.render('index');
    }
  });

index.ejs

<!-- 생략 -->

  <% if (locals.userInfo) { %>
    <h1><%= userInfo.name %>, <%= userInfo.point %></h1>
  <% } %>

 

728x90

'TIL' 카테고리의 다른 글

1월4일  (0) 2023.01.04
1월3일  (0) 2023.01.03
1월1일  (0) 2023.01.01
12월31일  (0) 2022.12.31
12월30일  (0) 2022.12.30