구글 로그인, 직접 안 짜도 되는 프롬프트 모음

auriclyn
3695
1 0

구글 로그인 직접 연동해보신 분들은 알 거예요.
OAuth는 문서 보면서 하려면 진짜 시간 오래 걸리고, access token 관리, callback 처리, 사용자 정보 매핑까지 은근 복잡하거든요.

근데 ChatGPT한테 딱 이렇게 물어보면, 우리가 직접 찾아보고 고민해야 할 부분까지 다 반영해서 코드를 짜줘요.
설계부터 보안까지 “이건 진짜 개발자가 쓴 것 같다” 싶은 수준으로 말이죠.

이번엔 Google OAuth2를 활용한 소셜 로그인 구현에 필요한 전체 구조를 이렇게 요청해봤어요👇

프롬프트

복사
넌 Next.js App Router 기반의 풀스택 애플리케이션을 구축할 수 있는 시니어 프론트엔드 개발자야. 나는 현재 소셜 로그인 기능 중 Google OAuth2를 활용한 로그인 연동을 구현하려고 해. 아래 환경과 목적, 그리고 요구사항을 기반으로 설계 및 구현에 필요한 전체 코드와 흐름을 작성해줘.

[환경 조건]
- 프레임워크: Next.js 13 이상 (App Router 구조)
- 언어: TypeScript
- 데이터베이스: PostgreSQL (Prisma ORM 사용)
- 인증/인가 방식: Google OAuth2
- 인증된 사용자의 access token은 쿠키(`httpOnly`, `Secure`, `SameSite=Strict`)에 저장
- 인증 처리에는 next-auth를 사용하지 않고, 직접 OAuth 연동 구현

[기능 목표]
1. 구글 OAuth 로그인 버튼 클릭 → Google 인증 창 → 인증 성공 시 redirect URI로 콜백
2. 콜백 처리 후 사용자 정보(email, name, profile image 등)를 수신하고,
   - 기존 유저가 존재하면 로그인 처리
   - 신규 유저라면 자동 회원가입 및 유저 DB 저장
3. 사용자에게 JWT access token 발급 → httpOnly 쿠키로 설정
4. JWT는 서버 사이드 렌더링 시에도 인증 확인이 가능하도록 설정
5. 로그인 상태가 유지되며, 페이지를 새로고침하거나 이동해도 인증 정보가 유지되어야 함
6. 로그아웃 시 쿠키를 완전히 삭제하고 세션 종료

[세부 요구]
- Google Cloud Console에서 필요한 OAuth 설정 방법(redirect URI, client ID/secret 구성법 등)도 요약해서 설명해줘
- Prisma User 모델에는 소셜 로그인 정보(`provider`, `providerAccountId`)가 명확히 들어가야 함
- 인증 실패 / 콜백 오류 / JWT 검증 실패 시 예외 처리 구조를 명확히 해줘
- 쿠키 설정 및 JWT 발급 함수는 유틸화하여 재사용 가능하도록 작성
- API 구조는 `/api/auth/google/start`, `/api/auth/google/callback`, `/api/auth/logout` 으로 명확히 나눠줘
- 코드에는 상세한 주석을 달아서 흐름을 따라가기 쉽도록 해줘
- 클라이언트 컴포넌트에서 로그인 버튼 클릭 시 흐름이 어떻게 동작하는지 포함해서 UI 코드도 같이 제공해줘

[추가 요청]
- JWT는 HS256으로 서명하고, access token 유효기간은 1시간
- access token 만료 시 자동으로 refresh되는 구조는 포함하지 않아도 됨
- 쿠키 설정 시 보안 옵션(`Secure`, `SameSite`, `httpOnly`)이 실제 배포 환경에서도 유효하게 작동하도록 해줘

이 조건을 기반으로 전체 폴더 구조, 코드 예시, 흐름 설명까지 포함한 완성도 높은 구현 가이드를 작성해줘.

댓글 작성

투자 수익률 5%에서 15%로, 그 비밀은 데이터에 있었다

주식시장에 뛰어든 지 2년, 제 포트폴리오 수익률은 고작 5%에 머물러 있었습니다. 주변 사람들은 두 자릿수 수익률을 자랑하...

숫자 뒤에 숨은 진실을 찾아라!

자산 투자에서 가장 무서운 건 뭘까요? 손실보다도 더 무서운 건 바로 '잘못된 신뢰'입니다. 화려한 수익률 그래프와 전문가 ...

프롬프트

공지

📢[필독] GPT 프롬프트 커뮤니티 이용 가이드

📢[필독] GPT 프롬프트 커뮤니티 이용 가이드

ChatGPT

기획안 시작할 때 뼈대부터 이렇게 잡습니다

ChatGPT

아스키 아트 이모지 만들기 (。•̀ᴗ-)✧

ChatGPT

회의록, 그냥 받아적지 말고 이렇게 설계하세요

ChatGPT

빅데이터로 트렌드 예측하기

ChatGPT

머릿속 1,000개의 아이디어를 어떻게 현실로 만들까?

ChatGPT

나만의 색깔을 찾아 떠나는 여정 – 어떻게 개인 브랜드를 명확하게 정의할 수 있을까?

ChatGPT

공부 미루는 습관 고치는 법..

ChatGPT

10시간 공부했는데 왜 기억나지 않을까? 과학적 학습법의 힘

ChatGPT

시험 3일 전, 500페이지를 어떻게 외웠을까?

ChatGPT

무의미한 회의가 사라진 날: 40분 회의가 10분으로 줄어든 비결

ChatGPT

재택근무 효율을 200% 끌어올린 나만의 프롬프트 기술

ChatGPT

직상생활..인간관계.. 어렵다..증말..

ChatGPT

요리가 너무 어려울 때, 나만의 초간단 해결법 찾은 썰

ChatGPT

자유롭게 글쓰는 방법 알고싶으시면 눌러보세용

ChatGPT

매번 버벅이던 전화 상담… 스크립트 템플릿으로 정리하니까 말이 술술 나옴

ChatGPT

이제 보험 아무거나 들고 후회하는 거 그만하려고요