Laravel UI

Laravel UI cung cấp một cách nhanh chóng để mở rộng các route và view cần thiết cho chức năng Authentication và bao gồm các cài đặt liên quan cho Bootstrap, React hoặc Vue.

Mặc dù nó vẫn tiếp tục hoạt động với phiên bản mới nhất của Laravel, nhưng bạn nên cân nhắc sử dụng Laravel Breeze cho các dự án mới. 

Hoặc, bạn muốn có một thư viện hỗ trợ mạnh mẽ hơn nữa, bạn có thể xem xét Laravel Jetstream.

Bạn có thể tìm hiểu thêm tại đây: https://github.com/laravel/ui

Thực hiện Authentication trong Laravel bằng Laravel UI

Trong bài viết này tôi sẽ hướng dẫn các bạn cách sử dụng Laravel UI để thực hiện chức năng Authentication trong dự án Laravel. (Phiên bản được áp dụng trong bài viết là Laravel 10).

Khởi tạo dự án Laravel

Đầu tiên, chúng ta sẽ khởi tạo dự án Laravel mới. Bạn có thể làm điều này bằng cách sử dụng lệnh sau:

composer create-project laravel/laravel laravel_ui

Bước tiếp theo, chúng ta sẽ tiến hành kết nối đến cơ sở dữ liệu bằng cách chỉnh sửa các thông tin sau trong tập tin .env:

DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=laravel_ui
DB_USERNAME=root
DB_PASSWORD=

Cuối cùng, chúng ta sẽ sử dụng lệnh sau để tạo ra các bảng mặc định trong Laravel:

php artisan migrate

Cài đặt Laravel UI

Đầu tiên, để bắt đầu, chúng ta cần cài đặt thư viện Laravel UI bằng cách chạy lệnh sau:

composer require laravel/ui

Tiếp theo, chúng ta sẽ sử dụng lệnh sau để tạo giao diện cho chức năng Authentication trong dự án Laravel của bạn:

1. Nếu dự án Laravel của bạn sử dụng Bootstrap, thì bạn hãy sử dụng lệnh sau:

php artisan ui bootstrap --auth

2. Nếu dự án Laravel của bạn sử dụng React, thì bạn hãy sử dụng lệnh sau:

php artisan ui react --auth

3. Nếu dự án Laravel của bạn sử dụng Vue, thì bạn hãy sử dụng lệnh sau:

php artisan ui vue --auth

Để bài hướng dẫn này trở nên đơn giản hơn, tôi sẽ thực hiện chức năng Authentication trong Laravel với Bootstrap.

Tiếp theo, chúng ta sẽ tiến hành cài đặt các thư viện NPM cần thiết. Để thực hiện việc này, bạn hãy chạy lệnh sau:

npm install

Ngoài ra, chúng ta nên cài đặt thêm thư viện resolve-url-loader để hỗ trợ chúng ta build SCSS thuận lợi hơn:

npm install resolve-url-loader@^4.0.0 --save-dev --legacy-peer-deps

Để biên dịch Assets, chúng ta cần phải sử dụng lệnh sau:

npm run build

Tiếp theo, chúng ta sẽ bắt đầu cài đặt thêm chức năng Email Verification, bạn hãy mở tập tin User.php nằm trong thư mục App/Models và chỉnh sửa như sau:

<?php

namespace App\Models;

use Illuminate\Contracts\Auth\MustVerifyEmail;
...

class User extends Authenticatable implements MustVerifyEmail
{
    ...
}

Sau đó, bạn hãy mở tập tin HomeController.php nằm trong thư mục app\Http\Controllers và chỉnh sửa như sau:

<?php

namespace App\Http\Controllers;

...

class HomeController extends Controller
{
    ...
    public function __construct()
    {
        $this->middleware('auth', 'verified');
    }
    ...
}

Tiếp theo, bạn mở tập tin web.php nằm trong thư mục routes và chỉnh sửa như sau:

<?php

use Illuminate\Support\Facades\Route;

...

Auth::routes(['verify' => true]);

Route::get('/home', [App\Http\Controllers\HomeController::class, 'index'])->name('home');

Tip Auth::routes() Parameters

Hầu hết chúng ta đều quen thuộc với phương thức Auth::routes(), một tính năng quan trọng từ gói Laravel UI.

Nhưng có bao giờ bạn tự hỏi, liệu có thể tùy chỉnh phương thức này để kích hoạt hoặc vô hiệu hóa các Route cụ thể của Laravel UI thông qua parameters không?

Dưới đây là danh sách các parameters và giá trị mặc định của Auth::routes() trong Laravel UI:

Auth::routes([
    'login'    => true,  # Bật/Tắt chức năng login của Laravel UI
    'logout'   => true,  # Bật/Tắt chức năng logout của Laravel UI
    'register' => true,  # Bật/Tắt chức năng register của Laravel UI
    'reset'    => true,  # Bật/Tắt chức năng reset của Laravel UI
    'confirm'  => false, # Bật/Tắt chức năng confirm của Laravel UI
    'verify'   => false, # Bật/Tắt chức năng verify của Laravel UI
]);

Kết quả của công việc bạn đã làm đang chờ bạn khám phá!

Sau khi đã hoàn thành các bước trên, giờ là lúc để chúng ta sẽ cùng nhau khám phá thành quả công sức của mình.

Trước khi chúng ta bắt đầu trải nghiệm tính năng chức năng Authentication sử dụng Laravel UI trong Laravel.

Chúng ta sẽ sử dụng Laravel Tinker  để tạo dữ liệu bảng users để thực hiện chức năng Login nếu bạn chưa thực hiện chức năng đăng kí tạo dữ liệu bảng users:

php artisan tinker

Tiếp theo, bạn hãy sử dụng tiếp lệnh sau để bắt đầu tạo dữ liệu bảng users:

\App\Models\User::factory(1)->create();

Login

Để thực hiện chức năng Login trong Laravel UI, bạn hãy truy cập vào URL bên dưới:

http://127.0.0.1:8000/login

Register

Để thực hiện chức năng Register trong Laravel UI, bạn hãy truy cập vào URL bên dưới:

http://127.0.0.1:8000/register

Reset Password

Để thực hiện chức năng Reset Password trong Laravel UI, bạn hãy truy cập vào URL bên dưới:

http://127.0.0.1:8000/password/reset

CÓ THỂ BẠN QUAN TÂM

Laravel CKEditor 5 Image Upload

Laravel CKEditor 5 Image Upload

CKEditor 5CKEditor 5 là một trình soạn thảo văn bản phong phú JavaScript với nhiều tính năng và khả năng tùy chỉnh. CKEditor 5 có kiến trúc MVC hiện đại, mô hình dữ liệu tùy chỉnh và DOM ảo, mang...

Integrating AI Assistant with CKEditor 5 in Laravel using Vite

Integrating AI Assistant with CKEditor 5 in Laravel using Vite

OpenAI OpenAI là một công ty nghiên cứu và triển khai trí tuệ nhân tạo, nổi tiếng với việc phát triển các mô hình AI tiên tiến. Mục tiêu của OpenAI là đảm bảo rằng trí tuệ nhân tạo tổng quát (AGI...

How to Install Laravel on CentOS 6/7

How to Install Laravel on CentOS 6/7

Laravel là một PHP Framework mã nguồn mở miễn phí, được phát triển bởi Taylor Otwell với phiên bản đầu tiên được ra mắt vào 6/2011. Laravel ra đời nhằm mục đích phát triển ứng dụng web dựa trên mô hìn...

Laravel User Authentication

Laravel User Authentication

Trong hướng dẫn này, tôi sẽ hướng dẫn bạn xây dựng chức năng đăng nhập trong Laravel. Công bằng mà nói thì bạn có thể sử dụng Laravel UI hoặc JetStream để tự động tạo ra chức năng đăng nhập trong Lara...

Laravel Custom Rules

Laravel Custom Rules

Trong quá trình phát triển website Laravel, mình cảm thấy hệ thống Validation của Laravel rất tuyệt vời, nó cung cấp đã cung cấp cho chúng ta một bộ quy tắc kiểm tra dữ liệu, mà trong các trường hợp b...

Laravel Mail Sending Redirector Listener

Laravel Mail Sending Redirector Listener

Trong quá trình phát triển web, việc gửi email là một chức năng quan trọng để thông báo, đặt lại mật khẩu, hoặc tương tác với người dùng. Tuy nhiên, khi chúng ta đang trong quá trình phát triển, vi...

Integrating Google Gemini AI in Laravel

Integrating Google Gemini AI in Laravel

Google Gemini Gemini là một mô hình trí tuệ nhân tạo mới mạnh mẽ từ Google không chỉ có khả năng hiểu văn bản mà còn có thể hiểu cả hình ảnh, video và âm thanh. Gemini là một mô hình đa phương ti...

Laravel Migration

Laravel Migration

Migration cho phép các nhà phát triển (Developer) nhanh chóng tạo ra cở sở dữ liệu của ứng dụng mà không cần vào màn hình quản lý cơ sở dữ liệu hay chạy bất kì một câu lệnh SQL nào. Trước hết, nếu...

Implementing Private User Folders with CKFinder in Laravel

Implementing Private User Folders with CKFinder in Laravel

CKFinder 3 CKFinder 3 là trình quản lý tập tin được tích hợp với CKEditor 4 và CKEditor 5. Nó giúp bạn dễ dàng đưa các tập tin và hình ảnh vào nội dung của Editor một cách an toàn. Đây là một tín...

ManhDanBlogs