With the increasing number of smartphone applications, the demand for mobile application development is increasing day by day. User login has become one of the very important functions in mobile applications, because user login can not only protect the security of user information, but also facilitate users. Quickly access their information on different devices. Laravel is a popular PHP framework that provides many built-in functions and extension packages to help developers implement various functions of the application, including the login function on the APP side. This article will introduce how to use Laravel to implement the APP login function.
1. Installation and configuration of Laravel
Before starting to implement the APP login function in Laravel, you need to install and configure the Laravel environment. First, make sure you have installed the Composer tool (https://getcomposer.org/). Next, run the following command to install Laravel in your computer.
composer create-project --prefer-dist laravel/laravel myapp
Where "myapp" is the name of the Laravel application you want to create.
After the installation is complete, you can enter the myapp directory and run the following command to start a local development server.
php artisan serve
Visit http://localhost:8000 to see the Laravel welcome page. Next, you need to install and configure the Passport extension package to support the login function on the APP side.
Run the following command to install the Passport extension pack:
composer require laravel/passport
After the installation is complete, run the following command to generate the necessary Passport key:
php artisan passport:keys
Next, run the following command To generate Passport database migration:
php artisan migrate
2. Implement the APP login function
- Create user model and controller
First, you need to create a User model so that applications can manage users. Run the following command to create a model named User:
php artisan make:model User
Next, create a controller named AuthController and add the following code in it:
<?php namespace AppHttpControllers; use AppModelsUser; use IlluminateHttpRequest; use IlluminateSupportFacadesAuth; use Validator; class AuthController extends Controller { public function register(Request $request) { $validator = Validator::make($request->all(), [ 'name' => 'required', 'email' => 'required|email|unique:users', 'password' => 'required', ]); if ($validator->fails()) { return response()->json(['error' => $validator->errors()], 401); } $user = new User; $user->name = $request->name; $user->email = $request->email; $user->password = bcrypt($request->password); $user->save(); $token = $user->createToken('MyApp')->accessToken; return response()->json(['token' => $token], 200); } public function login(Request $request) { $validator = Validator::make($request->all(), [ 'email' => 'required|email', 'password' => 'required', ]); if ($validator->fails()) { return response()->json(['error' => $validator->errors()], 401); } $credentials = $request->only('email', 'password'); if (Auth::attempt($credentials)) { $user = Auth::user(); $token = $user->createToken('MyApp')->accessToken; return response()->json(['token' => $token], 200); } else { return response()->json(['error' => 'Unauthorized'], 401); } } }
In the above code, The register method allows users to register, and the login method allows users to log in. If the user successfully registers or logs in, an access token is returned and is used for subsequent user requests.
- Create API routes
Next, you need to create corresponding API routes to handle user login and registration requests. In the routes/api.php file, add the following code:
<?php use IlluminateHttpRequest; use IlluminateSupportFacadesRoute; use AppHttpControllersAuthController; Route::post('/register', [AuthController::class, 'register']); Route::post('/login', [AuthController::class, 'login']);
The code above maps registration and login requests to the corresponding methods in the AuthController controller.
3. Test the login function
Now that all the code is ready, you can test the login and registration functions by accessing the following url.
-
POST /api/register
- Register a new user. Parameters: name, email, password.
-
POST /api/login
- Perform user login. Parameters: email, password.
#When the user logs in successfully, a token will be returned. This token can be used to make subsequent API requests to authenticate the user.
$token = 'Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6ImZlYTcwMDU3NzhlZWUyMTU3MzliNTM3ODQyNTI0NWJiMGM5YjA3ZWIyMWNlMDhhMDM5ODUyYjczMzVjNWE1NjJlN2UwMGU4ZTQ5MjhhNzg1In0.eyJhdWQiOiIxMSIsImp0aSI6ImZlYTcwMDU3NzhlZWUyMTU3MzliNTM3ODQyNTI0NWJiMGM5YjA3ZWIyMWNlMDhhMDM5ODUyYjczMzVjNWE1NjJlN2UwMGU4ZTQ5MjhhNzg1IiwiaWF0IjoxNjMwMzkwNTM3LCJuYmYiOjE2MzAzOTA1MzcsImV4cCI6MTYzMDM5NDAzNywiZGF0YSI6eyJ1c2VyIjp7ImlkIjoiMSJ9fX0.XsIFsVCc3N1oZ70vzWn4wHQSv3Q-JVdlfu4LJkUPL0he_53bpgJrq5jw8mHygB-1-kpq62N7eG_r08fXKkmbiqeITmUiaGKa0prKzXCoexuYKuxYqG8j-HY2UyDp5g_TE6M4eW5FrcDpTJ0WcQ5ShDhdszUFQUH_qR52ypeEUmsF6CFwx1YJt4AmCFEy2CjsKOMl9K9o0mV_ytvBZ9drY6w6HTRfYfU7q5yuM-W3Qp6bbS-ljzY_2M0RWzwZJm6QvO3Byjhw1TNUrPHFs6xGlY4M7zgkDZxas5srQgpFjKof2LztN7QAJaiT_d6XAKpS24JA2-v2U7x3g'; $response = $this->withHeaders([ 'Authorization' => $token, ])->json('GET', '/api/user');
In this example, use token to send a GET request to /api/user, which will return the user's information. If the login is unsuccessful, the API will return a 401 error code. If the login is successful, the user's information will be returned.
It is very easy to use the Passport extension package in Laravel to implement the login function on the APP side. You only need to install and configure the corresponding extension package. In this article, we demonstrate how to use Laravel to complete a complete APP-side login function, achieving quick login and security protection for users.
The above is the detailed content of laravel implements app-side login. For more information, please follow other related articles on the PHP Chinese website!

This article guides building robust Laravel RESTful APIs. It covers project setup, resource management, database interactions, serialization, authentication, authorization, testing, and crucial security best practices. Addressing scalability chall

This article provides a comprehensive guide to installing the latest Laravel framework using Composer. It details prerequisites, step-by-step instructions, troubleshooting common installation issues (PHP version, extensions, permissions), and minimu

This article guides Laravel-Admin users on menu management. It covers menu customization, best practices for large menus (categorization, modularization, search), and dynamic menu generation based on user roles and permissions using Laravel's author

This article details implementing OAuth 2.0 authentication and authorization in Laravel. It covers using packages like league/oauth2-server or provider-specific solutions, emphasizing database setup, client registration, authorization server configu

The article discusses creating and customizing reusable UI elements in Laravel using components, offering best practices for organization and suggesting enhancing packages.

This article guides Laravel developers in choosing the right version. It emphasizes the importance of selecting the latest Long Term Support (LTS) release for stability and security, while acknowledging that newer versions offer advanced features.

The article discusses creating and using custom validation rules in Laravel, offering steps to define and implement them. It highlights benefits like reusability and specificity, and provides methods to extend Laravel's validation system.

The article discusses best practices for deploying Laravel in cloud-native environments, focusing on scalability, reliability, and security. Key issues include containerization, microservices, stateless design, and optimization strategies.


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

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

Dreamweaver CS6
Visual web development tools

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool
