Supabase 는 오픈소스이며 Firebase의 대안입니다. Authentication(인증), Postgres Database(Postgres 데이터베이스), Edge Function(에지 함수), Realtime(실시간 구독) 및 Storage(스토리지) 를 제공합니다.
Supabase 프로젝트가 필요하며, 없을 경우, supabase.com 에 무료로 가입하여 새 프로젝트를 생성할 수 있습니다.
서버 측 랜더링 (SSR) 이 활성화된 Astro 프로젝트가 필요합니다.
프로젝트의 Supabase 자격 증명이 필요합니다. Supabase 프로젝트의 Settings > API 탭에서 이를 찾을 수 있습니다.
SUPABASE_URL
: Supabase 프로젝트의 URL입니다.
SUPABASE_ANON_KEY
: Supabase 프로젝트의 익명 키입니다.
Astro 프로젝트에 Supabase 자격 증명을 추가하려면 .env
파일에 다음을 추가하세요.
SUPABASE_URL =YOUR_SUPABASE_URL
SUPABASE_ANON_KEY =YOUR_SUPABASE_ANON_KEY
이제 프로젝트에서 이러한 환경 변수를 사용할 수 있습니다.
환경 변수에 IntelliSense를 사용하려면 src/
디렉터리의 env.d.ts
파일을 수정하거나 생성하여 다음을 추가하세요.
interface ImportMetaEnv {
readonly SUPABASE_URL : string
readonly SUPABASE_ANON_KEY : string
readonly env : ImportMetaEnv
이제 프로젝트에 다음 파일이 포함되어야 합니다.
디렉터리 src/
.env astro.config.mjs package.json
Supabase에 연결하려면 프로젝트에 @supabase/supabase-js
를 설치해야 합니다.
npm install @supabase/supabase-js
pnpm add @supabase/supabase-js
yarn add @supabase/supabase-js
다음으로, src/
디렉터리에 lib
라는 폴더를 생성합니다. 여기에 Supabase Client를 추가합니다.
supabase.ts
파일에 다음을 추가하여여 Supabase Client를 초기화합니다.
import { createClient } from " @supabase/supabase-js " ;
export const supabase = createClient (
import. meta . env . SUPABASE_URL ,
import. meta . env . SUPABASE_ANON_KEY ,
이제 프로젝트에 다음 파일이 포함되어야 합니다.
디렉터리 src/
.env astro.config.mjs package.json
Supabase는 즉시 인증을 제공합니다. GitHub, Google, Kakao 및 기타 여러 제공업체를 통해 이메일/비밀번호 인증과 OAuth 인증을 지원합니다.
Supabase로 초기화된 Astro 프로젝트가 필요합니다.
이메일/비밀번호 인증이 활성화된 Supabase 프로젝트가 필요합니다. Supabase 프로젝트의 Authentication > Providers 탭에서 이를 활성화할 수 있습니다.
프로젝트에 인증을 추가하려면 몇 가지 서버 엔드포인트를 생성해야 합니다. 이러한 엔드포인트는 사용자 등록, 로그인, 로그아웃 하는데 사용됩니다.
POST /api/auth/register
: 새로운 사용자를 등록합니다.
POST /api/auth/signin
: 사용자를 로그인합니다.
GET /api/auth/signout
: 사용자를 로그아웃합니다.
프로젝트의 src/pages/api/auth
디렉터리에 이러한 엔드포인트를 생성합니다. hybrid
렌더링 모드를 사용하는 경우, 각 파일 상단에 export const prerender = false
를 지정해야 요청에 따라 이러한 엔드포인트를 렌더링할 수 있습니다. 이제 프로젝트에 이러한 새 파일이 포함되어야 합니다.
디렉터리 src/
디렉터리 lib/
디렉터리 pages/
디렉터리 api/
디렉터리 auth/
signin.ts signout.ts register.ts env.d.ts .env astro.config.mjs package.json
register.ts
파일은 Supabase에서 새 사용자를 생성합니다. 이메일과 비밀번호가 포함된 POST
요청을 수락하고 Supabase SDK를 사용하여 새 사용자를 생성합니다.
// `output: 'hybrid'`가 구성된 경우:
// export const prerender = false;
import type { APIRoute } from " astro " ;
import { supabase } from " ../../../lib/supabase " ;
export const POST : APIRoute = async ( { request , redirect } ) => {
const formData = await request . formData () ;
const email = formData . get ( " email " ) ?. toString () ;
const password = formData . get ( " password " ) ?. toString () ;
if ( ! email || ! password) {
return new Response ( " Email and password are required " , { status: 400 } ) ;
const { error } = await supabase . auth . signUp ( {
return new Response (error . message , { status: 500 } ) ;
return redirect ( " /signin " ) ;
signin.ts
파일은 사용자를 로그인시킵니다. 이메일과 비밀번호가 포함된 POST
요청을 수락하고 Supabase SDK를 사용하여 사용자를 로그인합니다.
// `output: 'hybrid'`가 구성된 경우:
// export const prerender = false;
import type { APIRoute } from " astro " ;
import { supabase } from " ../../../lib/supabase " ;
export const POST : APIRoute = async ( { request , cookies , redirect } ) => {
const formData = await request . formData () ;
const email = formData . get ( " email " ) ?. toString () ;
const password = formData . get ( " password " ) ?. toString () ;
if ( ! email || ! password) {
return new Response ( " Email and password are required " , { status: 400 } ) ;
const { data , error } = await supabase . auth . signInWithPassword ( {
return new Response (error . message , { status: 500 } ) ;
const { access_token , refresh_token } = data . session ;
cookies . set ( " sb-access-token " , access_token , {
cookies . set ( " sb-refresh-token " , refresh_token , {
return redirect ( " /dashboard " ) ;
signout.ts
파일은 사용자를 로그아웃시킵니다. GET
요청을 수락하고 사용자의 엑세스 토큰 및 리프레시 토큰을 제거합니다.
// `output: 'hybrid'`가 구성된 경우:
// export const prerender = false;
import type { APIRoute } from " astro " ;
export const GET : APIRoute = async ( { cookies , redirect } ) => {
cookies . delete ( " sb-access-token " , { path: " / " } ) ;
cookies . delete ( " sb-refresh-token " , { path: " / " } ) ;
return redirect ( " /signin " ) ;
이제 서버 엔드포인트를 만들었으므로 이를 사용할 페이지를 만듭니다.
src/pages/register
: 새로운 사용자를 등록할 양식이 포함되어 있습니다.
src/pages/signin
: 사용자를 로그인하는 양식이 포함되어 있습니다.
src/pages/dashboard
: 인증된 사용자만 엑세스할 수 있는 페이지가 포함되어 있습니다.
src/pages
디렉터리에 이러한 페이지를 만듭니다. 이제 프로젝트에 다음과 같은 새 파일이 포함되어야 합니다.
디렉터리 src/
디렉터리 lib/
디렉터리 pages/
디렉터리 api/
디렉터리 auth/
signin.ts signout.ts register.tsregister.astro signin.astro dashboard.astro env.d.ts .env astro.config.mjs package.json
register.astro
파일에는 새 사용자를 등록하는 양식이 포함되어 있습니다. 이메일과 비밀번호를 입력받아 /api/auth/register
에 POST
요청을 보냅니다.
import Layout from " ../layouts/Layout.astro " ;
< Layout title = " Register " >
< p > Already have an account? < a href = " /signin " > Sign in </ a ></ p >
< form action = " /api/auth/register " method = " post " >
< label for = " email " > Email </ label >
< input type = " email " name = " email " id = " email " />
< label for = " password " > Password </ label >
< input type = " password " name = " password " id = " password " />
< button type = " submit " > Register </ button >
signin.astro
파일에는 사용자 로그인 양식이 포함되어 있습니다. 이메일과 비밀번호가 입력받아 /api/auth/signin
에 POST
요청을 보냅니다. 또한 엑세스 토큰 및 리프레시 토큰이 있는지 확인하고 존재하는 경우 대시보드로 리디렉션됩니다.
import Layout from " ../layouts/Layout.astro " ;
const { cookies , redirect } = Astro;
const accessToken = cookies . get ( " sb-access-token " );
const refreshToken = cookies . get ( " sb-refresh-token " );
if (accessToken && refreshToken) {
return redirect ( " /dashboard " );
< p > New here? < a href = " /register " > Create an account </ a ></ p >
< form action = " /api/auth/signin " method = " post " >
< label for = " email " > Email </ label >
< input type = " email " name = " email " id = " email " />
< label for = " password " > Password </ label >
< input type = " password " name = " password " id = " password " />
< button type = " submit " > Login </ button >
dashboard.astro
파일에는 인증된 사용자만 엑세스할 수 있는 페이지가 포함되어 있습니다. 엑세스 토큰 및 리프레시 토큰이 있는지 확인하고 존재하지 않는 경우 로그인 페이지로 리디렉션됩니다.
import Layout from " ../layouts/Layout.astro " ;
import { supabase } from " ../lib/supabase " ;
const { cookies , redirect } = Astro;
const accessToken = cookies . get ( " sb-access-token " );
const refreshToken = cookies . get ( " sb-refresh-token " );
if ( ! accessToken || ! refreshToken) {
return redirect ( " /signin " );
const { data , error } = await supabase . auth . setSession ( {
refresh_token: refreshToken . value ,
access_token: accessToken . value ,
cookies . delete ( " sb-access-token " , {
cookies . delete ( " sb-refresh-token " , {
return redirect ( " /signin " );
const email = data ?. user ?. email ;
< Layout title = " dashboard " >
< p > We are happy to see you here </ p >
< form action = " /api/auth/signout " >
< button type = " submit " > Sign out </ button >
프로젝트에 OAuth 인증을 추가하려면 Supabase Client를 편집하여 "pkce"
를 통한 인증 흐름을 활성화해야 합니다. Supabase 문서 에서 인증 흐름에 대한 자세한 내용을 확인할 수 있습니다.
import { createClient } from " @supabase/supabase-js " ;
export const supabase = createClient (
import. meta . env . SUPABASE_URL ,
import. meta . env . SUPABASE_ANON_KEY ,
그런 다음 Supabase 대시보드에서 사용하려는 OAuth 공급자를 활성화합니다. Supabase 프로젝트의 Authentication > Providers 탭에서 지원되는 공급자 목록을 찾을 수 있습니다.
다음 예시에서는 GitHub를 OAuth 공급자로 사용합니다. 프로젝트를 GitHub에 연결하려면, Supabase 문서 의 단계를 따르세요.
그런 다음 src/pages/api/auth/callback.ts
파일에 OAuth 콜백을 처리할 새 서버 엔드포인트를 생성합니다. 이 엔드포인트는 OAuth 코드를 엑세스 토큰 및 리프레시 토큰으로 교환하는 데 사용됩니다.
import type { APIRoute } from " astro " ;
import { supabase } from " ../../../lib/supabase " ;
export const GET : APIRoute = async ( { url , cookies , redirect } ) => {
const authCode = url . searchParams . get ( " code " ) ;
return new Response ( " No code provided " , { status: 400 } ) ;
const { data , error } = await supabase . auth . exchangeCodeForSession (authCode) ;
return new Response (error . message , { status: 500 } ) ;
const { access_token , refresh_token } = data . session ;
cookies . set ( " sb-access-token " , access_token , {
cookies . set ( " sb-refresh-token " , refresh_token , {
return redirect ( " /dashboard " ) ;
그런 다음 OAuth 공급자로 로그인하기 위한 새 버튼을 포함하도록 로그인 페이지를 수정합니다. 이 버튼은 OAuth 공급자의 이름으로 설정된 provider
를 포함하여 /api/auth/signin
에 POST
요청을 보내야 합니다.
import Layout from " ../layouts/Layout.astro " ;
const { cookies , redirect } = Astro;
const accessToken = cookies . get ( " sb-access-token " );
const refreshToken = cookies . get ( " sb-refresh-token " );
if (accessToken && refreshToken) {
return redirect ( " /dashboard " );
< p > New here? < a href = " /register " > Create an account </ a ></ p >
< form action = " /api/auth/signin " method = " post " >
< label for = " email " > Email </ label >
< input type = " email " name = " email " id = " email " />
< label for = " password " > Password </ label >
< input type = " password " name = " password " id = " password " />
< button type = " submit " > Login </ button >
< button value = " github " name = " provider " type = " submit " > Sign in with GitHub </ button >
마지막으로 OAuth 공급자를 처리하도록 로그인 서버 엔드포인트를 수정합니다. provider
가 있으면 OAuth 공급자로 리디렉션됩니다. 그렇지 않으면 이메일과 비밀번호를 사용하여 사용자를 로그인합니다.
import type { APIRoute } from " astro " ;
import { supabase } from " ../../../lib/supabase " ;
import type { Provider } from " @supabase/supabase-js " ;
export const POST : APIRoute = async ( { request , cookies , redirect } ) => {
const formData = await request . formData () ;
const email = formData . get ( " email " ) ?. toString () ;
const password = formData . get ( " password " ) ?. toString () ;
const provider = formData . get ( " provider " ) ?. toString () ;
const validProviders = [ " google " , " github " , " discord " ] ;
if (provider && validProviders . includes (provider)) {
const { data , error } = await supabase . auth . signInWithOAuth ( {
provider: provider as Provider ,
redirectTo: " http://localhost:4321/api/auth/callback "
return new Response (error . message , { status: 500 } ) ;
return redirect (data . url ) ;
if ( ! email || ! password) {
return new Response ( " Email and password are required " , { status: 400 } ) ;
const { data , error } = await supabase . auth . signInWithPassword ( {
return new Response (error . message , { status: 500 } ) ;
const { access_token , refresh_token } = data . session ;
cookies . set ( " sb-access-token " , access_token , {
cookies . set ( " sb-refresh-token " , refresh_token , {
return redirect ( " /dashboard " ) ;
OAuth 콜백 엔드포인트를 생성하고 로그인 페이지와 서버 엔드포인트를 수정한 후 프로젝트 파일 구조는 다음과 같습니다.
디렉터리 src/
디렉터리 lib/
디렉터리 pages/
디렉터리 api/
디렉터리 auth/
signin.ts signout.ts register.ts callback.ts register.astro signin.astro dashboard.astro env.d.ts .env astro.config.mjs package.json
더 많은 백엔드 서비스 안내서
Recipes