JWT(JSON 웹 토큰)로 보안 API를 구축할 때 사용자 로그아웃을 처리하는 것이 까다로울 수 있습니다. JWT는 상태 비저장이므로 로그아웃 후 토큰을 무효화하는 기본 방법이 없습니다. Redis와 같은 블랙리스트와 도구가 작동하는 곳이 바로 여기입니다. 이러한 개념이 처음이더라도 걱정하지 마세요! 이 가이드는 모든 것을 단계별로 설명하고 실용적인 솔루션을 구현하는 데 도움이 됩니다.
상태 비저장 시스템
JWT
블랙리스트는 무효화된 토큰 목록입니다. 사용자가 로그아웃하면 해당 토큰이 이 목록에 추가됩니다. 요청이 이루어질 때마다 서버는 토큰이 블랙리스트에 있는지 확인합니다. 그렇다면 요청이 거부됩니다.
블랙리스트 구현 단계:
Redis는 고성능 인메모리 키-값 데이터베이스입니다. 다음과 같은 이유로 JWT 블랙리스트 작성과 같은 사용 사례에 적합합니다.
이러한 개념이 처음이라면 간단한 인메모리 솔루션으로 시작해 보세요.
const blacklist = new Set(); // Add token to blacklist authController.logout = (req, res) => { const token = req.headers.authorization.split(" ")[1]; blacklist.add(token); res.status(200).json({ message: "Logged out successfully" }); }; // Middleware to check token validity middleware.verifyToken = (req, res, next) => { const token = req.headers.authorization.split(" ")[1]; if (blacklist.has(token)) { return res.status(401).json({ message: "Invalid token" }); } next(); };
이 접근 방식은 소규모 프로젝트에 적합하지만 제한 사항이 있습니다. 앱이 확장된다면 Redis와 같은 더욱 강력한 솔루션이 필요합니다.
ioredis 라이브러리를 사용하여 Node.js 앱에서 Redis와 상호 작용하세요.
const blacklist = new Set(); // Add token to blacklist authController.logout = (req, res) => { const token = req.headers.authorization.split(" ")[1]; blacklist.add(token); res.status(200).json({ message: "Logged out successfully" }); }; // Middleware to check token validity middleware.verifyToken = (req, res, next) => { const token = req.headers.authorization.split(" ")[1]; if (blacklist.has(token)) { return res.status(401).json({ message: "Invalid token" }); } next(); };
npm install ioredis
Feature | In-Memory (Set) | Redis |
---|---|---|
Scalability | Limited to a single server | Distributed across servers |
Speed | Very fast | Equally fast |
Persistence | Lost on server restart | Data persists across restarts |
Cleanup | Manual | Automatic with TTL |
인메모리 솔루션으로 간단하게 시작하여 점진적으로 Redis로 전환하면 부담을 덜 수 있습니다. 즐거운 코딩하세요!
Redis 설정과 관련하여 질문이 있거나 도움이 필요하면 댓글로 알려주시기 바랍니다. ?
위 내용은 블랙리스트 및 Redis를 사용하여 JWT 로그아웃 관리: 초보자에게 친숙한 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!