최신 웹 애플리케이션에서는 리소스에 액세스하거나 수정할 수 있는 사람을 제어하는 것이 중요합니다. 예를 들어, 블로그 애플리케이션에서는 게시물 소유자만 게시물을 편집하거나 삭제할 수 있도록 할 수 있습니다. Laravel은 인증을 처리하는 두 가지 우아한 방법, 즉 게이트와 정책 클래스를 제공합니다. 이 가이드는 두 가지 방법을 모두 안내하여 리소스를 보호하고 애플리케이션의 보안을 보장하는 방법을 보여줍니다.
Gates는 클로저를 사용하여 승인을 처리하는 빠르고 간단한 방법을 제공합니다. 이는 간단한 인증 확인에 적합하며 AuthServiceProvider에 정의되어 있습니다.
게시물 소유자만 게시물을 업데이트하거나 삭제할 수 있도록 게이트를 정의해 보겠습니다.
게이트 정의: AuthServiceProvider를 열고 게이트 정의를 추가합니다.
// app/Providers/AuthServiceProvider.php use Illuminate\Support\Facades\Gate; use App\Models\Post; public function boot() { $this->registerPolicies(); Gate::define('update-post', function ($user, Post $post) { return $user->id === $post->user_id; }); Gate::define('delete-post', function ($user, Post $post) { return $user->id === $post->user_id; }); }
게이트 적용: 컨트롤러 메서드에서 게이트를 사용하여 인증 논리를 시행합니다.
// app/Http/Controllers/PostController.php use Illuminate\Http\Request; use Illuminate\Support\Facades\Gate; use App\Models\Post; public function update(Request $request, Post $post) { if (Gate::denies('update-post', $post)) { abort(403, 'You do not own this post. ?'); } // Proceed with updating the post } public function destroy(Post $post) { if (Gate::denies('delete-post', $post)) { abort(403, 'You do not own this post. ?'); } // Proceed with deleting the post }
장점:
단점:
최고의 사용 사례: 빠른 인증 확인이 필요한 소규모 애플리케이션 또는 간단한 사용 사례입니다. ?
정책 클래스는 승인 처리에 대해 보다 구조화되고 확장 가능한 접근 방식을 제공합니다. 복잡한 인증 규칙을 관리하고 코드를 체계적으로 유지하는 명확한 방법을 제공합니다. 정책은 표준 CRUD 작업인 index, create, edit, update 및 파괴.
정책 생성 및 사용정책 생성: Artisan을 사용하여 정책 클래스 생성:
php artisan make:policy PostPolicy
정책 방법 정의: 생성된 정책 클래스를 열고 각 작업에 대한 인증을 처리하는 방법을 추가합니다.
// app/Policies/PostPolicy.php namespace App\Policies; use App\Models\User; use App\Models\Post; class PostPolicy { /** * Determine if the user can view the list of posts. * * @param User $user * @return bool */ public function viewAny(User $user) { // Example logic to allow viewing posts for authenticated users return true; } /** * Determine if the user can create a post. * * @param User $user * @return bool */ public function create(User $user) { return true; } /** * Determine if the user can update the post. * * @param User $user * @param Post $post * @return bool */ public function update(User $user, Post $post) { return $user->id === $post->user_id; } /** * Determine if the user can delete the post. * * @param User $user * @param Post $post * @return bool */ public function delete(User $user, Post $post) { return $user->id === $post->user_id; } }
정책 사용: 컨트롤러 작업에 정책 메서드를 적용합니다.
// app/Http/Controllers/PostController.php use Illuminate\Http\Request; use App\Models\Post; public function update(Request $request, Post $post) { $this->authorize('update', $post); // Proceed with updating the post } public function destroy(Post $post) { $this->authorize('delete', $post); // Proceed with deleting the post }
장점:
단점:
최상의 시나리오: 인증 요구 사항이 복잡한 애플리케이션이나 깨끗하고 유지 관리 가능한 코드를 목표로 하는 경우에 이상적입니다. ?
index, create, edit, 업데이트, 파기합니다. 애플리케이션의 요구 사항에 가장 적합한 방법을 선택하고 안전하고 잘 구성된 코드베이스를 즐겨보세요! ??
위 내용은 Laravel의 인증 - 초보자 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!