Files
TK-FB-Project/docker-compose.yml
Hyungi Ahn 790d12fe13 feat: 토큰 만료 시 자동 로그아웃 기능 추가 및 테이블명 수정
🔐 토큰 만료 시 자동 로그아웃 기능:
1. JWT 토큰 만료 시간 대폭 연장:
   - 액세스 토큰: 24시간 → 7일
   - 리프레시 토큰: 7일 → 30일
   - 사용자 편의성 크게 향상

2. 토큰 만료 감지 및 처리:
   - isTokenExpired() 함수 추가
   - JWT 페이로드 파싱하여 exp 확인
   - 현재 시간과 비교하여 만료 여부 판단

3. 자동 로그아웃 처리:
   - API 호출 시 401 오류 감지
   - 주기적 토큰 만료 확인 (5분마다)
   - 만료 시 자동 인증 데이터 정리
   - 사용자 알림 후 로그인 페이지 리다이렉트

4. 개선된 인증 데이터 관리:
   - clearAuthData() 함수로 통합 관리
   - token, user, userInfo, currentUser 모두 정리
   - 메모리 누수 방지

🐛 데이터베이스 테이블명 수정:
1. projectModel.js:
   - Projects → projects (대문자 → 소문자)
   - 실제 DB 테이블명과 일치

2. taskModel.js:
   - Tasks → tasks (대문자 → 소문자)
   - 실제 DB 테이블명과 일치

3. API 오류 해결:
   - '테이블이 존재하지 않습니다' 오류 수정
   - projects, tasks API 정상 작동

 사용자 경험 개선:
- 토큰 만료로 인한 예상치 못한 오류 방지
- 명확한 만료 알림 메시지
- 자동 로그아웃으로 보안 강화
- 더 긴 세션 유지로 편의성 향상

🔧 기술적 개선:
- JWT 페이로드 안전한 파싱
- 에러 핸들링 강화
- 주기적 백그라운드 확인
- 전역 함수로 재사용성 향상

🎯 결과:
- 안정적인 인증 시스템
- 사용자 친화적인 세션 관리
- 보안성과 편의성의 균형
- API 호출 오류 해결

테스트:
- 토큰 만료 후 자동 로그아웃 확인
- projects, tasks API 정상 작동 확인
2025-11-03 12:49:25 +09:00

123 lines
2.7 KiB
YAML

version: "3.8"
services:
# MariaDB 데이터베이스
db:
image: mariadb:10.9
container_name: tkfb_db
restart: unless-stopped
environment:
- MYSQL_ROOT_PASSWORD=tkfb2024!
- MYSQL_DATABASE=hyungi
- MYSQL_USER=hyungi_user
- MYSQL_PASSWORD=hyungi2024!
volumes:
- db_data:/var/lib/mysql
- ./api.hyungi.net/migrations:/docker-entrypoint-initdb.d
ports:
- "20306:3306"
healthcheck:
test: ["CMD", "mysqladmin", "ping", "-h", "localhost"]
timeout: 20s
retries: 10
networks:
- tkfb_network
# Node.js API 서버
api:
build:
context: ./api.hyungi.net
dockerfile: Dockerfile
container_name: tkfb_api
depends_on:
db:
condition: service_healthy
restart: unless-stopped
ports:
- "20005:3005"
environment:
- NODE_ENV=production
- PORT=3005
- DB_HOST=db
- DB_PORT=3306
- DB_USER=hyungi_user
- DB_PASSWORD=hyungi2024!
- DB_NAME=hyungi
- DB_ROOT_PASSWORD=tkfb2024!
- JWT_SECRET=tkfb_jwt_secret_2024_hyungi_secure_key
- JWT_EXPIRES_IN=7d
- JWT_REFRESH_EXPIRES_IN=30d
volumes:
- ./api.hyungi.net/public/img:/usr/src/app/public/img:ro
- ./api.hyungi.net/uploads:/usr/src/app/uploads
- ./api.hyungi.net/logs:/usr/src/app/logs
- ./api.hyungi.net/routes:/usr/src/app/routes
- ./api.hyungi.net/controllers:/usr/src/app/controllers
- ./api.hyungi.net/models:/usr/src/app/models
- ./api.hyungi.net/index.js:/usr/src/app/index.js
logging:
driver: "json-file"
options:
max-size: "10m"
max-file: "3"
networks:
- tkfb_network
# Web UI (Nginx)
web:
build:
context: ./web-ui
dockerfile: Dockerfile
container_name: tkfb_web
restart: unless-stopped
ports:
- "20000:80"
volumes:
- ./web-ui:/usr/share/nginx/html:ro
depends_on:
- api
networks:
- tkfb_network
# FastAPI Bridge
fastapi:
build:
context: ./fastapi-bridge
dockerfile: Dockerfile
container_name: tkfb_fastapi
restart: unless-stopped
ports:
- "20008:8000"
environment:
- API_BASE_URL=http://api:3005
depends_on:
- api
networks:
- tkfb_network
# phpMyAdmin
phpmyadmin:
image: phpmyadmin/phpmyadmin:latest
container_name: tkfb_phpmyadmin
depends_on:
- db
restart: unless-stopped
ports:
- "20080:80"
environment:
- PMA_HOST=db
- PMA_USER=root
- PMA_PASSWORD=tkfb2024!
- UPLOAD_LIMIT=50M
networks:
- tkfb_network
volumes:
db_data:
driver: local
networks:
tkfb_network:
driver: bridge
name: tkfb_network