TripTalk은 사용자의 여행 스타일과 선호도를 기반으로 AI가 최적의 여행 일정을 생성해주는 플랫폼입니다. FastAPI 기반 AI 서버와 연동하여 개인 맞춤형 여행 계획을 제공하며, 실시간 항공권 및 숙소 정보를 조회하여 편리한 여행 준비를 지원합니다.
- 🤖 AI 맞춤 추천: 사용자 취향 기반 여행 일정 자동 생성
✈️ 실시간 정보: Amadeus API 연동 항공권 조회- 🗺️ 커서 페이징: 무한 스크롤 방식의 부드러운 UX
- 🔐 보안: JWT 기반 인증/인가 시스템
- 회원가입/로그인 (JWT Access & Refresh Token)
- 토큰 재발급 (Refresh Token 기반)
- 로그아웃 (Refresh Token 삭제)
- 여행 추천 카드 및 배너
- 인기 여행지 소개 (제주도, 부산, 파리, 뉴욕 등)
- 카테고리별 여행 상품 탐색
- AI 여행 플래너 바로가기
- FastAPI AI 서버 연동
- 여행 스타일 분석 (체험·액티비티, 자연, 힐링, 로컬 등 9가지)
- 목적지, 기간, 예산, 동행인 기반 맞춤 일정 생성
- 일정 자동 저장
- 일별 상세 스케줄 (DailySchedule → ScheduleItem)
- 교통편 정보 (출발/귀환)
- 숙소 정보
- 여행 하이라이트
- 상태별 조회
- PLANNED (계획 중)
- TRAVELED (여행 완료)
- 커서 기반 무한스크롤 (페이지 사이즈 5개)
- 여행 상태 변경 (PLANNED → TRAVELED)
- 여행 계획 상세 조회
- 전체 일정, 교통편, 숙소, 하이라이트 포함
- Amadeus API 연동
- 인기 노선 자동 조회
- 국내: 김포↔제주, 김포↔부산
- 일본: 인천↔도쿄/오사카/후쿠오카 등
- 기타: 방콕, 싱가포르, 홍콩, 뉴욕, 파리 등 20개 노선
- 주간 스케줄러 (매주 월요일 새벽 4시 자동 업데이트)
- 커서 기반 무한스크롤 (페이지 사이즈 10개)
- 국가별 대표 이미지 매핑
- 추천 숙소 조회
- 18개 도시 × 3개 호텔
- 다양한 체크인/체크아웃 날짜 (오늘 +7~14일)
- 커서 기반 무한스크롤 (페이지 사이즈 10개)
- 테마별 조회
- NATURE (자연)
- SEA (바다)
- CULTURE (문화)
- HEALING (힐링)
- HISTORY (역사)
- 커서 기반 무한스크롤 (페이지 사이즈 10개)
- 개인 프로필 관리
- 여행 통계 (완료한 여행, 계획 중인 여행, 적립 포인트)
- 뱃지 시스템 (첫 여행, 시간 마니아, 한번가 등)
- 계정 설정 및 개인정보 변경
- Language: Java 21
- Framework: Spring Boot 3.5.6
- ORM: Spring Data JPA (Hibernate 6.6.29)
- Database: MySQL 8.0 (AWS RDS)
- Security: Spring Security + JWT (jjwt 0.12.3)
- API Docs: Swagger (SpringDoc OpenAPI 2.7.0)
- Build Tool: Gradle 8.x
- Amadeus API: 실시간 항공권 정보 조회
- FastAPI: AI 기반 여행 일정 생성 서버
- Server: AWS EC2
- Database: AWS RDS (MySQL)
- Container: Docker
┌─────────────┐ ┌──────────────┐ ┌─────────────┐
│ Client │ ───> │ Spring Boot │ ───> │ MySQL │
│ (Mobile) │ │ (REST API) │ │ (RDS) │
└─────────────┘ └──────────────┘ └─────────────┘
│
├──────> FastAPI (AI 서버)
│
└──────> Amadeus API (항공권)
┌──────────────────────────────────────┐
│ Controller Layer │ ← REST API 엔드포인트
├──────────────────────────────────────┤
│ Service Layer │ ← 비즈니스 로직
├──────────────────────────────────────┤
│ Converter Layer │ ← DTO ↔ Entity 변환
├──────────────────────────────────────┤
│ Repository Layer │ ← DB 접근 (JPA)
└──────────────────────────────────────┘
http://54.180.99.252:8080
http://52.78.55.147:8080/swagger-ui/index.html#/
- Java 21
- MySQL 8.0
- Gradle 8.x
git clone https://github.com/your-repo/triptalk.git
cd triptalkCREATE DATABASE triptalk_db CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;spring:
datasource:
url: jdbc:mysql://localhost:3306/triptalk_db
username: your-username
password: your-password
jwt:
secret: your-jwt-secret-key-at-least-32-characters
access-token-expiration: 3600000 # 1시간
refresh-token-expiration: 1209600000 # 2주
amadeus:
api-key: your-amadeus-api-key
api-secret: your-amadeus-api-secret# 빌드
./gradlew clean build
# 실행
./gradlew bootRun
# 또는 JAR 파일 실행
java -jar build/libs/triptalk-0.0.1-SNAPSHOT.jardocker-compose up -d- Server: AWS EC2 (Amazon Linux 2)
- Database: AWS RDS MySQL 8.0
- Domain: 54.180.99.252:8080
- Swagger: http://54.180.99.252:8080/swagger-ui/index.html
- Offset 방식 대비 대용량 데이터 처리 성능 우수
- 실시간 데이터 변경에도 안정적
- 무한 스크롤 UX 최적화
- Access Token (1시간) + Refresh Token (2주)
- Stateless 인증 방식
- Spring Security FilterChain 적용
- DTO ↔ Entity 변환 로직 분리
- Service 계층 간결화
- 재사용성 및 유지보수성 향상
- 여행 스타일 한글 문자열 → Enum 자동 변환
- DB 정규화 및 타입 안정성 확보
- 실시간 항공권 가격 조회
- 주간 스케줄러 자동 업데이트
- 환율 자동 변환 (EUR/USD → KRW)
src/main/java/com/example/triptalk/
├── domain/
│ ├── user/
│ │ ├── controller/ # 사용자 관련 API
│ │ ├── service/ # 사용자 비즈니스 로직
│ │ ├── repository/ # 사용자 DB 접근
│ │ ├── entity/ # User, RefreshToken 엔티티
│ │ └── dto/ # 요청/응답 DTO
│ │
│ ├── tripPlan/
│ │ ├── controller/ # 여행 계획, 항공권, 숙소 API
│ │ ├── service/ # 여행 계획 생성/관리 로직
│ │ ├── converter/ # DTO ↔ Entity 변환
│ │ ├── repository/ # JPA Repository
│ │ ├── entity/ # TripPlan, DailySchedule 등
│ │ ├── dto/ # Request/Response DTO
│ │ ├── enums/ # TravelStyle, TripStatus
│ │ ├── scheduler/ # 항공권 자동 업데이트
│ │ └── util/ # 국가 이미지 매핑
│ │
│ └── tripPlace/
│ ├── controller/ # 여행지 추천 API
│ ├── service/ # 여행지 조회 로직
│ ├── repository/ # 여행지 DB 접근
│ └── entity/ # TripPlace 엔티티
│
├── global/
│ ├── apiPayload/ # 공통 응답 포맷
│ ├── config/ # Security, Swagger 설정
│ └── security/ # JWT 인증/인가
│
└── TriptalkApplication.java
🌟 TripTalk과 함께 완벽한 여행을 계획하세요!