🔐 토큰 만료 시 자동 로그아웃 기능: 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 정상 작동 확인
123 lines
2.7 KiB
YAML
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
|