엔티티 및 Repository 설계:
EventUser 엔티티 외에, 이메일 인증 과정을 추적하기 위한 별도의 엔티티EmailVerification를 설계했습니다. 이 테이블에는 인증 코드, 만료 시간이 기록됩니다.JpaRepository를 생성했습니다.비동기 이메일 발송:
@Async)로 처리하여 API 응답이 지연되지 않도록 설계했습니다.상태를 가진 인증 프로세스:
GET /api/auth/check-email?email=... 과 같은 엔드포인트를 통해, 가입 전에 이미 사용 중인 이메일인지 실시간으로 확인할 수 있는 API를 제공했습니다.POST /api/auth/code?email=...&code=... 요청 시, 서버는 사용자가 입력한 코드와 DB에 저장된 코드가 일치하는지, 그리고 만료 시간이 지나지 않았는지를 검증합니다. 검증 성공 시, 해당 이메일은 "인증 완료" 상태로 변경됩니다.단계별 UI 구성 (Multi-step Form):
실시간 유효성 검증 및 디바운싱:
lodash 라이브러리의 debounce 함수를 사용하여, 불필요한 API 요청을 최소화하고 서버 부하를 줄였습니다.인증 코드 입력 UI 및 로직:
ref 바인딩: 인증 코드 4자리를 각각의 <input>으로 나누어 구현하고, 사용자가 한 칸을 입력하면 다음 칸으로 자동으로 포커스가 이동하도록 ref 배열을 사용하여 DOM을 직접 제어했습니다.host-config.js)로 분리하여 관리의 효율성을 높였습니다.ref를 활용한 자동 포커스 이동과 타이머 기능으로 사용 편의성을 높였습니다.