Laravel 개발: Laravel Sanctum을 사용하여 SPA 인증을 구현하는 방법은 무엇입니까?
Laravel 개발: Laravel Sanctum을 사용하여 SPA 인증을 구현하는 방법은 무엇입니까?
Laravel Sanctum은 SPA(Single Page Application) 및 모바일 애플리케이션에 간단하고 가벼운 API 인증을 제공하도록 설계된 Laravel의 공식 패키지입니다. 보안 강화를 위해 영구 자격 증명 대신 임시 토큰을 사용하고 쿠키, API 키, JWT를 포함한 여러 인증 드라이버를 제공합니다.
이 글에서는 Laravel Sanctum을 사용하여 SPA 인증을 구현하는 방법에 대해 설명합니다.
첫 번째 단계는 Laravel Sanctum을 설치하는 것입니다. Laravel 애플리케이션에서 Composer를 사용하여 설치할 수 있습니다:
composer require laravel/sanctum
composer require laravel/sanctum
安装后,需要运行migrations以创建Sanctum所需的表:
php artisan migrate
接下来,需要打开app/Http/Kernel.php文件,并在API中间件组中添加Laravel Sanctum的中间件:
LaravelSanctumHttpMiddlewareEnsureFrontendRequestsAreStateful::class, 'throttle:60,1', IlluminateRoutingMiddlewareSubstituteBindings::class, ],``` 现在,Laravel Sanctum已准备好开始在应用程序中进行SPA身份验证。 下一步是将Sanctum添加到Vue或React应用程序中。为此,需要在应用程序中安装axios或其他HTTP客户端库,以便与后端通信。建议使用axios来演示下面的示例代码。 axios需要配置一下:
import axios from 'axios'
export const HTTP = axios.create({
baseURL: http://localhost:8000/api/
설치 후 Sanctum에 필요한 테이블을 생성하려면 마이그레이션을 실행해야 합니다:
php artisan migration< /code><p><br>다음으로, app/Http/Kernel.php 파일을 열고 API 미들웨어 그룹에 Laravel Sanctum 미들웨어를 추가해야 합니다: </p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>
withCredentials选项允许axios将cookie发送到后端,这对于使用Laravel Sanctum进行身份验证非常重要。
现在,可以在Vue组件或React组件中使用以下代码来进行身份验证:
</pre><div class="contentsignin">로그인 후 복사</div></div><p>import axios from 'axios'</p><p>export const HTTP = axios .create({<br> baseURL: <code>http://localhost:8000/api/
, withCredentials: true,})
axios.post('/login', this.credentials) .then(response => { this.getUser() })
// Login
login() {
axios.post('/logout') .then(response => { this.$store.commit('logout') })
},
// 로그아웃
logout() {
axios.get('/user') .then(response => { this.$store.commit('updateUser', response.data) }).catch(error => { console.log(error) })
},
// 사용자 정보 가져오기
在这个例子中,我们使用axios来向/login和/logout路由发送POST请求,以及向/user路由发送GET请求。这三个路由应该在Laravel应用程序中定义,并使用Laravel Sanctum进行身份验证。 使用Laravel Sanctum的默认身份验证驱动程序- cookie-,可以通过以下方式发送令牌:
这将在每个请求中设置名为X-CSRF-TOKEN的标头。此标头包含一个CSRF令牌,该令牌是在使用Laravel Sanctum时进行身份验证所必需的。
위 내용은 Laravel 개발: Laravel Sanctum을 사용하여 SPA 인증을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Laravel 이메일 전송이 실패 할 때 반환 코드를 얻는 방법. Laravel을 사용하여 응용 프로그램을 개발할 때 종종 확인 코드를 보내야하는 상황이 발생합니다. 그리고 실제로 ...

laravel 일정 작업 실행 비 응답 문제 해결 Laravel의 일정 작업 일정을 사용할 때 많은 개발자 가이 문제에 직면합니다 : 스케줄 : 실행 ...

Laravel의 이메일을 처리하지 않는 방법은 LaRavel을 사용하는 것입니다.

DCAT를 사용할 때 DCATADMIN (LARAVEL-ADMIN)에서 데이터를 추가하려면 사용자 정의의 테이블 기능을 구현하는 방법 ...

Laravel 프레임 워크 및 Laravel 프레임 워크 및 Redis를 사용할 때 Redis 연결을 공유하는 데 영향을 줄 수 있습니다. 개발자는 문제가 발생할 수 있습니다. 구성을 통해 ...

Laravel 다중 테넌트 확장 패키지 패키지 패키지 패키지 패키지 Stancl/Tenancy, ...

Laravel - 액션 URL - Laravel 5.7에는 "호출 가능한 액션 URL"이라는 새로운 기능이 도입되었습니다. 이 기능은 액션 메소드에서 문자열을 허용하는 Laravel 5.6의 기능과 유사합니다. Laravel 5.7에 도입된 새로운 구문의 주요 목적은

Laraveleloquent 모델 검색 : 데이터베이스 데이터를 쉽게 얻을 수 있습니다. 이 기사는 데이터베이스에서 데이터를 효율적으로 얻는 데 도움이되는 다양한 웅변 모델 검색 기술을 자세히 소개합니다. 1. 모든 기록을 얻으십시오. 모든 () 메소드를 사용하여 데이터베이스 테이블에서 모든 레코드를 가져옵니다. 이것은 컬렉션을 반환합니다. Foreach 루프 또는 기타 수집 방법을 사용하여 데이터에 액세스 할 수 있습니다 : Foreach ($ postas $ post) {echo $ post->
