express
CHAPTER 21 / 34
읽기 약 2분
FUNCTION
사용자 인증 API
핵심 개념
회원가입/로그인 API를 구현합니다. bcrypt로 비밀번호를 해시하고, JWT로 액세스 토큰을 발급합니다.
코드 분석
사용자 인증 API
const bcrypt = require('bcryptjs')
const jwt = require('jsonwebtoken')
// 회원가입
app.post('/auth/signup', async (req, res) => {
const { email, password } = req.body
const hashed = await bcrypt.hash(password, 10)
const user = { id: Date.now(), email, password: hashed }
users.push(user)
res.status(201).json({ message: 'Signup ok' })
})
// 로그인
app.post('/auth/login', async (req, res) => {
const user = users.find(u => u.email === req.body.email)
const valid = await bcrypt.compare(req.body.password, user.password)
if (!valid) return res.status(401).json({ error: 'Wrong password' })
const token = jwt.sign({ id: user.id }, process.env.JWT_SECRET, { expiresIn: '1h' })
res.json({ token })
})AI 프롬프트
🤖 AI에게 잘 물어보는 법 — 모델·전략별 프롬프트
Claude
무료: Sonnet 4.6 / Pro $20/mo: Opus 4.6
이 Express '사용자 인증 API' 미들웨어 체인에서 요청 처리 순서 버그·에러 전파 누락·메모리 누수를 찾아서 수정해줘.
ChatGPT
무료: GPT-5.5 / Plus $20/mo: GPT-5.5 Pro
'사용자 인증 API'를 사용한 RESTful API를 CRUD 4개 엔드포인트가 포함된 완성 코드로 만들어줘.
Gemini
무료: 2.5 Flash / Pro $19.99/mo: 3.1 Pro
이 Express '사용자 인증 API' 라우트 구조와 미들웨어 체인 전체를 분석해서 응답 시간·동시성·로깅 개선안을 정리해줘.
Grok
무료: Grok 4.1 / SuperGrok $30/mo
Express '사용자 인증 API' vs Fastify·Hono의 동일 기능 구현을 2026년 기준 성능과 생태계로 솔직히 비교해줘.
⭐ 이것만 기억하세요
사용자 인증 API는 이 3가지만 확실히 잡으세요
1.인증 없이 API를 운영하면 누구나 다른 사용자의 데이터를 읽고 수정할 수 있습니다
2.bcrypt로 비밀번호를 해싱해서 저장하고, 로그인 성공 시 JWT를 발급하며, 이후 요청에서 토큰으로 사용자를 식별합니다
3.다음 챕터에서 게시글 CRUD와 페이지네이션을 갖춘 게시판 API를 구현합니다
공유하기
진행도 21 / 34