비밀번호 재설정도, GPT가 설계부터 같이 해줘요

세이멘토
2,155
1 0

회원가입 다음으로 중요한 기능이 비밀번호 재설정이죠.
사용자 UX도 중요하지만, 토큰 만료, 인증 링크 보안, 악용 방지까지 생각하면 진짜 섬세하게 설계해야 하는 기능입니다.

근데 ChatGPT한테 아래처럼 요청하면 보안 흐름 + 코드 구조 + UI UX 흐름까지 한 번에 정리해서 주니까
혼자 고민하고 설계하는 시간 줄고, 실무에서도 그대로 적용할 수 있어요.

이번엔 이메일 기반 비밀번호 재설정 기능을 요청한 프롬프트입니다

프롬프트

복사
넌 보안과 인증 흐름에 능숙한 시니어 풀스택 개발자야. 나는 현재 내 Next.js 기반 웹사이트에 비밀번호 재설정(Reset Password) 기능을 직접 구현하고 싶어. 아래 요구사항을 기반으로 전체 구조, 보안 고려, UI 흐름, 코드를 포함한 완전한 구현 가이드를 제공해줘.

[기본 환경]
- 프레임워크: Next.js 13+ (App Router 구조)
- 언어: TypeScript
- 데이터베이스: PostgreSQL (Prisma ORM)
- 인증은 이메일 기반
- 이메일 전송은 nodemailer 또는 추천 SMTP 라이브러리 사용
- 비밀번호는 bcrypt로 암호화 저장

[기능 흐름 요약]
1. 사용자가 이메일을 입력 → 비밀번호 재설정 요청  
2. 서버는 고유한 리셋 토큰을 생성하고 DB에 저장 (만료 시간 포함, 예: 15분)
3. 사용자 이메일로 토큰 포함된 재설정 링크 전송 (예: `https://example.com/reset?token=abc123`)
4. 사용자가 해당 링크 클릭 → 클라이언트에서 토큰 확인 → 새 비밀번호 입력
5. 서버에서 토큰 검증 → 유효하면 비밀번호 업데이트, 토큰은 즉시 삭제

[보안 요구사항]
- 토큰은 단방향 해시로 저장 (단순 문자열 저장 X)
- 링크는 1회용이어야 하며, 만료 시간 이후엔 무효화
- 비밀번호는 최소 길이/복잡도 조건 만족해야 함
- 이메일 유효성 체크 필요 (존재하지 않는 이메일에도 노출 안 되도록 처리)
- 사용자 피싱 방지를 위해 UX도 신경 써야 함 (예: 성공/실패 메시지 동일 처리)

[기술 구현 요청]
- Prisma 모델에 `ResetToken` 테이블 설계 포함 (userId, tokenHash, expiresAt 등)
- `/api/auth/request-reset`, `/api/auth/verify-token`, `/api/auth/reset-password` 구조로 API 구성
- 토큰 생성/검증 로직은 유틸 함수로 분리
- 서버에서 쿠키 사용은 필요 없음
- 이메일 템플릿 구성 예시 포함
- 클라이언트 측에서 `reset password form`과 UX 흐름도 예시 코드로 제공
- 모든 코드에 상세한 주석 작성

이 요구사항을 기반으로 백엔드 로직, 프론트 컴포넌트, 이메일 템플릿, 예외 처리 흐름까지 포함해 전체 코드를 작성해줘.

이렇게 GPT에게 구조부터 목적, 보안 조건, API 설계 방향, UI 흐름까지 함께 요청하면
단순한 코드 조각이 아닌 실제 제품 수준의 설계와 구현 예시가 나옵니다.

비밀번호 재설정도 혼자 설계할 필요 없이,
GPT랑 “협업하듯” 일하면 진짜 시간도 줄고, 실수도 줄어요.
여러분은 어떤 식으로 리셋 기능 구현하고 계신가요? 공유해주세요!

댓글 작성

주니어에서 시니어까지, 5년을 3년으로 압축한 비밀

지금도 기억나요. 첫 회사 입사 후 3개월 차에 받았던 피드백이요. "코딩은 잘하는데, 전체적인 그림을 못 보는 것 같아요." ...

“작은 습관이 만드는 부의 차이”

매달 월급의 대부분이 생활비와 소비로 사라지는 현실. 직장인들이 가장 많이 공감하는 고민이 아닐까요? 한 직장인은 10년간...

프롬프트

ChatGPT

마이너 코드에 잠긴 기억 선율은 나의 마음을 움직인다.

ChatGPT

사과과 떨어지는데 위로 떨어진다!!??(창의적 사고)

ChatGPT

뇌가 공부에 빠지는 순간

ChatGPT

한 푼도 쓰지 않는 날의 자유(자산의 관리)

ChatGPT

포스토 속에서 색깔의 형태가 속삭이는 것들

ChatGPT

당신의 글속의 문장들은 춤을 추고 있나요?

ChatGPT

모든 위대한 창작은 한순간의 망상에서 시작된다

ChatGPT

주니어에서 시니어까지, 5년을 3년으로 압축한 비밀

ChatGPT

하루 8시간 일하던 제가 4시간 만에 끝내는 법

ChatGPT

“불가능”이라는 말을 들었을 때 오히려 신나는 이유

ChatGPT

휴대폰으로 찍은 사진이 갤러리에 전시된 비결

ChatGPT

2천만원 날린 후에야 깨달은 투자의 진실

ChatGPT

온라인 수업이 대면 수업보다 효과적일 수 있다는 발견

ChatGPT

6개월 후 내 코드를 보고 “이게 뭐지?” 했던 경험

ChatGPT

팀원들이 “매일 출근하고 싶다”고 말하는 비밀

ChatGPT

실패작 100개를 만든 후에야 깨달은 진실