Implementing PHP security verification using Laravel Passport
Using Laravel Passport to implement PHP security authentication
Introduction:
In modern web development, user authentication and authorization are very important security functions. Laravel Passport is an OAuth2-based authentication tool that can help us easily implement user authentication and authorization functions. This article explains how to implement secure authentication in PHP using Laravel Passport.
Steps:
-
Install Laravel Passport
First, make sure the Laravel framework is installed. Next, enter the project directory in the terminal and execute the following command to install the Laravel Passport package:composer require laravel/passport
Copy after loginAfter successful installation, run the following command to publish the files and database migrations required by the package:
php artisan passport:install
Copy after login Configure Passport
Open theconfig/app.php
file and add the following service provider in theproviders
array:LaravelPassportPassportServiceProvider::class,
Copy after loginThen, in the
$routeMiddleware
array in theapp/Http/Kernel.php
file, add the following middleware:'client' => LaravelPassportHttpMiddlewareCheckClientCredentials::class,
Copy after loginFinally, in the
file:app /User.php
Add theHasApiTokens
trait ofPassport
to the /User.phpuse LaravelPassportHasApiTokens;
Copy after loginand introduce it in the
trait array of the class:Now, we have successfully configured Laravel Passport.use HasApiTokens;
Copy after login
First, we need to create a controller to handle user authentication requests. You can execute the following command to generate a new controller:
Create user authentication interfacephp artisan make:controller AuthController
Copy after loginThen, add the following method in
AuthController to handle registration and login requests:
Create RoutesOpen the
routes/api.php
:
Use Passport GuardOpen
config/auth.phpfile, and change the
apiguard driver to
passport
, you can add the following route:
Use authenticated userNow, we can use the
auth:apimiddleware to authenticate users and secure related API routes. For example, in
AuthControllerpublic function profile() { $user = Auth::user(); return response()->json(['user' => $user], 200); }
Copy after loginThen, in
routes/api.php, add the following route:Route::get('profile', 'AuthController@profile')->middleware('auth:api');
Copy after loginIn this way, when accessing the
/api/profile route, the user will be asked to provide a valid authentication token first.
use IlluminateHttpRequest; use IlluminateSupportFacadesAuth; class AuthController extends Controller { public function register(Request $request) { // 验证请求数据 $request->validate([ 'name' => 'required|unique:users', 'email' => 'required|email|unique:users', 'password' => 'required|min:6' ]); // 创建用户 $user = User::create([ 'name' => request('name'), 'email' => request('email'), 'password' => bcrypt(request('password')), ]); // 生成访问令牌 $token = $user->createToken('accessToken')->accessToken; // 返回响应 return response()->json(['token' => $token], 200); } public function login(Request $request) { // 验证请求数据 $credentials = request(['email', 'password']); // 检查用户凭据 if (!Auth::attempt($credentials)) { return response()->json(['message' => 'Unauthorized'], 401); } // 获取当前用户 $user = $request->user(); // 生成访问令牌 $token = $user->createToken('accessToken')->accessToken; // 返回响应 return response()->json(['user' => $user, 'token' => $token], 200); } }
Route::post('register', 'AuthController@register'); Route::post('login', 'AuthController@login')->middleware('client');
'guards' => [ 'api' => [ 'driver' => 'passport', 'provider' => 'users', ], ],
Summary:
The above is the detailed content of Implementing PHP security verification using Laravel Passport. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

To work on file upload we are going to use the form helper. Here, is an example for file upload.

In this chapter, we are going to learn the following topics related to routing ?

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

Validator can be created by adding the following two lines in the controller.
