Express 개발 강좌, 세션 및 쿠키를 이용한 사용자 인증

웹 애플리케이션에서 사용자 인증은 매우 중요한 요소입니다. 사용자가 자신을 확인할 수 있도록 해주며, 이는 개인화된 경험과 보안을 제공합니다. 이 강좌에서는 Express 프레임워크를 사용하여 세션과 쿠키를 활용한 사용자 인증 시스템을 구축하는 방법에 대해 설명합니다. 이를 위해 express-sessioncookie-parser 미들웨어를 사용할 것입니다.

1. Express 및 관련 모듈 설치

개발을 시작하기 위해 우선 Express와 필요한 미들웨어를 설치해야 합니다. npm을 사용하여 다음과 같이 설치합니다:

        npm install express express-session cookie-parser body-parser
    

여기서 설치된 각 패키지의 역할은 다음과 같습니다:

  • express: Node.js를 위한 간단한 웹 애플리케이션 프레임워크
  • express-session: 세션 미들웨어로, 클라이언트의 세션을 관리합니다
  • cookie-parser: 쿠키를 쉽게 파싱할 수 있게 해주는 미들웨어입니다
  • body-parser: 요청 본문(body)을 파싱할 수 있도록 도와줍니다

2. 기본 Express 서버 설정

기본 Express 서버를 설정하는 방법은 간단합니다. 서버 파일을 생성하고 필요한 모듈을 임포트한 후, 서버를 시작하는 코드를 작성해 보겠습니다.

        
const express = require('express');
const session = require('express-session');
const cookieParser = require('cookie-parser');
const bodyParser = require('body-parser');

const app = express();
const PORT = 3000;

// 미들웨어 설정
app.use(cookieParser());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(session({
    secret: '비밀 키', // 세션을 암호화하는 데 사용할 키
    resave: false,
    saveUninitialized: true,
    cookie: { secure: false } // SSL 사용시 true로 변경
}));

// 기본 라우터 설정
app.get('/', (req, res) => {
    res.send('Welcome to the Express App');
});

app.listen(PORT, () => {
    console.log(`서버가 http://localhost:${PORT}에서 실행 중입니다.`);
});
        
    

위 코드를 실행하면 기본 Express 서버가 준비됩니다. 이제 사용자가 인증할 수 있도록 세션을 설정해 보겠습니다.

3. 사용자 인증 라우트 만들기

사용자 인증을 위해 로그인 및 로그아웃 라우트를 만듭니다. 사용자는 로그인할 때 세션이 생성되고 로그아웃하면 세션이 삭제됩니다.

        
// 로그인 라우터
app.post('/login', (req, res) => {
    const { username, password } = req.body;

    // 간단한 사용자 인증 (실제로는 데이터베이스를 확인해야 함)
    if (username === 'user' && password === 'password') {
        req.session.user = username; // 세션에 사용자 정보를 저장
        res.send('로그인 성공!');
    } else {
        res.send('로그인 실패: 잘못된 사용자 이름 또는 비밀번호');
    }
});

// 로그아웃 라우터
app.post('/logout', (req, res) => {
    req.session.destroy((err) => {
        if (err) {
            return res.send('로그아웃 실패');
        }
        res.send('로그아웃 성공');
    });
});
        
    

위의 코드는 간단한 로그인 프로세스를 보여줍니다. 실제 애플리케이션에서는 데이터베이스에서 사용자 정보를 확인하는 것이 좋습니다. 이 세션 정보를 통해 사용자가 로그인 상태인지 여부를 확인할 수 있습니다.

4. 사용자가 로그인했는지 확인하기

사용자가 로그인했는지를 확인하는 미들웨어를 작성해 보겠습니다. 이 미들웨어는 특정 라우트에 접근하기 전에 호출되어 사용자의 인증 상태를 확인합니다.

        
// 인증 미들웨어
function isAuthenticated(req, res, next) {
    if (req.session.user) {
        return next(); // 로그인한 상태
    } else {
        res.status(401).send('로그인 필요');
    }
}

// 보호된 라우트
app.get('/dashboard', isAuthenticated, (req, res) => {
    res.send(`환영합니다, ${req.session.user}님! 대시보드에 오신 것을 환영합니다.`);
});
        
    

이제 /dashboard 경로로 접근할 때 사용자 인증 상태를 확인할 수 있습니다. 로그인하지 않은 사용자는 401 오류 메시지를 받게 됩니다.

5. 쿠키를 이용한 사용자 인증

사용자가 로그인할 때 쿠키를 설정하여 인증을 유지하는 방법도 있습니다. 쿠키에는 사용자 정보를 저장할 수 있으며, 클라이언트 측에서 쉽게 접근이 가능합니다.

        
app.post('/login', (req, res) => {
    const { username, password } = req.body;

    if (username === 'user' && password === 'password') {
        req.session.user = username;
        res.cookie('username', username, { 
            maxAge: 900000, // 쿠키 만료 시간
            httpOnly: true // JavaScript에서 액세스 금지
        });
        res.send('로그인 성공!');
    } else {
        res.send('로그인 실패: 잘못된 사용자 이름 또는 비밀번호');
    }
});
        
    

위의 코드는 로그인 성공 시 쿠키를 설정하는 방법을 보여줍니다. 쿠키의 속성으로는 maxAgehttpOnly를 설정했습니다. httpOnly 속성은 JavaScript에서 액세스할 수 없도록 하여 보안을 강화합니다.

6. 쿠키와 세션의 차이점

쿠키와 세션은 둘 다 사용자 인증에 사용되지만, 그 동작 방식은 다릅니다:

  • 쿠키: 클라이언트 측에 저장되며, 사용자의 브라우저에 남아 있는 데이터입니다. 따라서 사용자가 브라우저를 종료하더라도 쿠키는 만료 시까지 유지됩니다.
  • 세션: 서버 측에 저장되며, 보통 사용자가 로그인하는 동안 유지됩니다. 사용자가 로그아웃하거나 세션이 만료되면 삭제됩니다.

쿠키는 클라이언트 측에서 쉽게 접근할 수 있는 반면, 세션은 서버에서 안전하게 관리되므로 보안이 강화됩니다.

7. 보안 강화하기

사용자 인증을 할 때 보안을 강화하는 것은 매우 중요합니다. 다음은 몇 가지 보안 수칙입니다:

  • HTTPS 사용: 모든 트래픽을 암호화하여 중간자 공격을 방지합니다.
  • 세션 무작위화: 세션 ID를 무작위로 생성하여 예측할 수 없도록 합니다.
  • 최소 권한 원칙: 사용자가 필요한 권한만 부여하여 시스템에 대한 접근을 최소화합니다.
  • 비밀번호 해시화: 사용자의 비밀번호를 해시 알고리즘(예: bcrypt)을 사용하여 안전하게 저장합니다.

8. 결론

이번 강좌에서는 Express 프레임워크를 이용하여 세션 및 쿠키를 활용한 사용자 인증 방법에 대해 알아보았습니다. 기본적인 인증 시스템을 구축하는 데 필요한 코드와 원리를 이해했기를 바랍니다. 사용자 인증은 웹 애플리케이션의 중요한 구성 요소이며, 안전하고 효율적인 방법으로 구현해야 합니다. 이제 여러분은 세션과 쿠키를 사용하여 사용자 인증 시스템을 구축하고 보안을 강화하는 방법을 배웠으니, 이를 바탕으로 더욱 발전된 기능을 구현해 보시기 바랍니다.

Tip: 사용자 인증 시스템을 구성할 때는 항상 최신 보안 표준을 따르고, 정기적으로 코드를 검토하여 취약점을 방지하는 것이 중요합니다.

9. 추가 자료

더 깊은 이해를 원하신다면 다음과 같은 자료들을 참고하시기 바랍니다:

10. Q&A

질문이 있으시면 댓글에 남겨주세요. 함께 해결해 보도록 하겠습니다!