이메일 인증 기능도 그냥 GPT한테 맡겨

세이튜터
1,560
0 0

회원가입 만들다가 문득 생각남.
“이거 가입만 되면 뭐해. 인증도 안 되는데…” 😅

그래서 이메일 인증 흐름까지 GPT한테 던져봤는데
와… 진짜 다 해준다. 토큰 발급부터 검증, DB에 저장, 메일 전송, 보안 처리까지.
우리가 설계하면서 고민할 거 GPT가 먼저 챙겨서 짜줌.

아래 프롬프트 이대로 복붙하면 됨

프롬프트

복사
넌 인증/보안 기능에 숙련된 시니어 풀스택 개발자야. 나는 지금 Next.js 기반 회원가입 시스템에 "이메일 인증 기반 계정 활성화" 기능을 추가하려고 해. 아래 환경, 목표, 보안 기준에 맞게 전체 구조와 코드를 작성해줘.
[기술 스택 및 환경]
- 프레임워크: Next.js 13 이상 (App Router 구조)
- 언어: TypeScript
- ORM: Prisma
- 데이터베이스: PostgreSQL
- 메일 전송: nodemailer 또는 추천 SMTP 라이브러리
- 비밀번호 암호화: bcrypt
[기능 흐름 요약]
1. 유저가 이메일/비번으로 회원가입
2. 서버는 inactive 계정 만들고 인증 토큰 생성해서 저장
3. 유저 메일로 인증 링크 전송
4. 유저가 링크 클릭 → 토큰 검증 → 계정 활성화
5. 링크는 24시간 유효 + 1회용
6. 인증 안 된 계정은 로그인 불가
[보안 처리 포함]
- 토큰은 단방향 해시로 저장 (절대 평문 X)
- 만료/잘못된 토큰 처리 확실히
- 인증 안 된 계정은 로그인 차단 + 메시지 출력
- 인증 결과 페이지도 만들어줘 (성공/실패/만료 상태 안내)
[요청하는 것]
- Prisma 모델 구성 (User + Token 테이블)
- API route (`/api/auth/register`, `/api/auth/verify-email`)
- 메일 보내는 유틸 함수
- 인증 토큰 생성/검증 로직
- 회원가입 UI 예시
- 인증 결과 페이지 예시
- 코드에 주석 달아줘
전체 구조 설계부터 코드, 예외 처리까지 완성된 예시로 줘.




요거 하나면 이메일 인증 기능은 끝.
심지어 DB 설계 + 보안 고려 + UX 흐름까지 포함된 코드로 받아볼 수 있어서
진짜 MVP 만들 땐 이렇게 GPT랑 협업하는 게 최고임.

혹시 인증 다음에 2FA(구글 OTP)까지 붙이고 싶으면,
그 프롬프트도 정리해둔 거 있음. 댓글 달면 바로 뿌릴게요 😎

댓글 작성

기획서대로 했는데 왜 아무도 감동하지 않을까?

작년에 진행한 브랜딩 프로젝트를 떠올리면 지금도 아찔해요. 완벽한 일정표, 세밀한 예산 계획, 단계별 체크포인트까지 모든...

투자, 감정에 흔들리지 않는 다섯 가지 방법

주식 시장이 급등락할 때마다 마음이 조마조마해지신 적 있으신가요? 많은 투자자들이 정보에 휘둘리고, 순간의 감정에 따라 ...

프롬프트

ChatGPT

“시장은 항상 변한다, 하지만 변화의 패턴은 읽을 수 있다”

ChatGPT

“진짜 교육 혁신은 강연장이 아니라 복도에서 일어난다”

ChatGPT

“보안은 마지막에 확인하는 게 아니라 처음부터 끝까지 함께 가는 것”

ChatGPT

“한 번의 클릭이 회사 전체를 마비시킬 수도 있다”

ChatGPT

“창의성을 숫자로 평가한다고? 불가능해 보였던 일이 현실이 되다”

ChatGPT

“교육의 질이 곧 미래의 질이다”

ChatGPT

“예술가의 꿈이 디지털로 날개를 달다”

ChatGPT

“정보가 돈이다, 하지만 잘못된 정보는 독이다”

ChatGPT

“사용자는 하나의 서버만 보지만, 뒤에는 100대가 숨어있다”

ChatGPT

“협력업체는 우리 팀이 아니다”라는 착각이 사업을 망친다

ChatGPT

“회의실에서 가장 예측 가능한 사람이 되지 마라”

ChatGPT

“붓 대신 데이터로, 캔버스 대신 알고리즘으로”

ChatGPT

“폭풍 속에서도 흔들리지 않는 수익, 어떻게 만들까?”

ChatGPT

“아이들의 미래가 데이터 유출로 망가질 수는 없다”

ChatGPT

“100만 사용자를 넘나드는 순간, 데이터베이스가 무릎을 꿇었다”

ChatGPT

“사고 없는 일터는 운이 아니라 시스템의 결과다”