Breeze를 사용하는 React 앱용 Laravel Sanctum 인증
라라벨 브리즈는 웹과 API를 위한 인증 스캐폴딩입니다. Breeze는 Laravel Sanctum for Authentication 시스템에 의해 구동되며 기본적으로 CSRF 보호, 세션 인증을 포함하므로 XSS 공격에 대해 걱정할 필요가 없습니다.
이 기사에서는 Breeze API 스캐폴딩을 사용하여 React 애플리케이션을 인증하는 방법을 볼 수 있습니다. 통합하자
Laravel 백엔드 설정
Laravel 애플리케이션을 생성하고 아래 명령을 사용하여 Laravel breeze API 스캐폴딩을 설치합니다.
# Create a laravel application
composer create-project laravel/laravel react-backend
cd react-backend
# Install Breeze
composer require laravel/breeze
php artisan breeze:install api
위의 명령을 실행한 후 env의 FRONTEND_URL을 localhost:3000으로 업데이트하고 Laravel Sail 또는 php artisan serve 명령을 사용하여 애플리케이션을 제공합니다.
앱을 테스트하려면 브라우저에서
localhost:8000
를 누르십시오. 아래와 같이 응답으로 앱 버전을 얻을 수 있습니다.{
"Laravel": "8.77.1"
}
이제 Laravel 백엔드 앱은 React 앱의 요청을 처리할 준비가 되었습니다. 다음으로 반응 앱을 설정해 보겠습니다.
React 앱 설정
Create React App을 사용하여 아래 명령을 사용하여 React 앱을 설정합니다.
npx create-react-app breeze-react
cd breeze-react
yarn start
Axios 구성
API를 처리하기 위해 Axios를 사용합니다. 아래와 같이 글로벌 Axios 클라이언트 추가
withCredentials
교차 사이트 쿠키 액세스를 활성화하려면 true로 설정하십시오. REACT_APP_BACKEND_URL은 이전에 만든 Laravel 백엔드 앱인 localhost:8000
파일에 .env
있습니다.
CSRF 요청
Laravel breeze는 인증을 위해 sanctum을 사용하므로 SPA를 인증합니다. /sanctum/csrf-cookie
끝점에 첫 번째 요청을 해야 합니다. 인증되지 않은 모든 경로에서 이 요청을 해야 합니다. 예를 들어 로그인, 등록, 비밀번호를 잊어버렸습니다.
hooks/auth.js
파일에 사용자 지정 후크를 생성하고 아래 코드를 추가하여 csrf 요청을 처리합니다.
<script id="gist-ltag"src="https://gist.github.com/Nilanth/204a989d470162044baf572dbf5588bb.js"/>
로그인 API 통합
useAuth
후크에 아래 로그인 기능을 추가합니다
<script id="gist-ltag"src="https://gist.github.com/Nilanth/1ee06af8e59df77c22ce6d4ed7a4d0ab.js"/>
로그인 API 요청 시 먼저 CSRF API를 요청하고 성공 시 로그인 API를 요청합니다. 마찬가지로 등록, 비밀번호 분실, 비밀번호 재설정 API를 사용할 수 있습니다. 이제 React App을 Laravel Breeze API 스캐폴딩과 통합했습니다.
Laravel Breeze 반응
Laravel breeze react는 GitHub에서 사용할 수 있는 React용 Breeze 인증 상용구 구현입니다. TailwindCSS 및 CRA를 사용하는 모든 인증 API, 경로 및 기본 UI로 사전 구성됩니다.
특징
<올>
React Router 6 라우팅용
SWR 재검증 사용자 데이터용
빠른 시작 가이드
laravel-breeze-react를 복제하고 yarn install
를 사용하여 종속성을 설치한 다음 .env.example
파일을 .env
에 복사하고 아래와 같이 백엔드의 URL을 추가합니다
REACT_APP_BACKEND_URL=http://localhost:8000
실행yarn start
, 이제 브라우저에 아래 화면이 표시됩니다
laravel-breeze-react는 인증 레이어를 처리하므로 비즈니스 로직에만 집중할 수 있습니다.
자원
Laravel Breeze Docs
Laravel Breeze React repository
Sanctum Docs
결론
Laravel Breeze는 SPA 인증을 매우 간단하고 안전하게 만들고 Laravel Breeze React는 Laravel Breeze Backend 앱과 React 앱을 빠르게 통합합니다.
읽어주셔서 감사합니다.
에서 더 많은 업데이트를 받으세요.
무료 전자책
ReactJS Optimization Techniques and Development Resources
더 많은 블로그
<올>
<리/>
<리/>
<리/>
<리/>
<리/>
<리/>
<리/>
<리/>
<리/>
<리/>
<리/>
Reference
이 문제에 관하여(Breeze를 사용하는 React 앱용 Laravel Sanctum 인증), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/nilanth/laravel-sanctum-authentication-for-react-app-using-breeze-2l5f텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)