Laravel - Bộ điều khiển
Trong khuôn khổ MVC, chữ 'C' là viết tắt của Controller. Nó hoạt động như một lưu lượng truy cập trực tiếp giữa Chế độ xem và Mô hình. Trong chương này, bạn sẽ tìm hiểu về Bộ điều khiển trong Laravel.
Tạo bộ điều khiển
Mở dấu nhắc lệnh hoặc thiết bị đầu cuối dựa trên hệ điều hành bạn đang sử dụng và nhập lệnh sau để tạo bộ điều khiển bằng Artisan CLI (Giao diện dòng lệnh).
php artisan make:controller <controller-name> --plain
Thay thế <controller-name> bằng tên của bộ điều khiển của bạn. Điều này sẽ tạo ra một phương thức khởi tạo đơn giản khi chúng ta truyền đối số -plain. Nếu bạn không muốn tạo một phương thức khởi tạo đơn giản, bạn có thể đơn giản bỏ qua đối số. Hàm tạo đã tạo có thể được nhìn thấy tạiapp/Http/Controllers.
Bạn sẽ thấy rằng một số mã hóa cơ bản đã được thực hiện cho bạn và bạn có thể thêm mã hóa tùy chỉnh của mình. Bộ điều khiển đã tạo có thể được gọi từ route.php theo cú pháp sau.
Cú pháp
Route::get(‘base URI’,’controller@method’);
Thí dụ
Step 1 - Thực hiện lệnh sau để tạo UserController.
php artisan make:controller UserController --plain
Step 2 - Sau khi thực hiện thành công, bạn sẽ nhận được kết quả như sau.
Step 3 - Bạn có thể xem bộ điều khiển đã tạo tại app/Http/Controller/UserController.php với một số mã cơ bản đã được viết cho bạn và bạn có thể thêm mã của riêng mình dựa trên nhu cầu của bạn.
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class UserController extends Controller {
//
}
Phần mềm trung gian điều khiển
Chúng tôi đã thấy phần mềm trung gian trước đây và nó cũng có thể được sử dụng với bộ điều khiển. Phần mềm trung gian cũng có thể được gán cho tuyến đường của bộ điều khiển hoặc trong phương thức khởi tạo của bộ điều khiển của bạn. Bạn có thể sử dụng phương pháp phần mềm trung gian để gán phần mềm trung gian cho bộ điều khiển. Phần mềm trung gian đã đăng ký cũng có thể bị hạn chế đối với một số phương pháp nhất định của bộ điều khiển.
Gán phần mềm trung gian cho tuyến đường
Route::get('profile', [
'middleware' => 'auth',
'uses' => 'UserController@showProfile'
]);
Ở đây chúng tôi đang gán phần mềm trung gian auth cho UserController trong tuyến hồ sơ.
Gán phần mềm trung gian trong phương thức khởi tạo của Bộ điều khiển
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class UserController extends Controller {
public function __construct() {
$this->middleware('auth');
}
}
Ở đây chúng tôi đang giao auth phần mềm trung gian sử dụng phương pháp phần mềm trung gian trong UserController constructor.
Thí dụ
Step 1 - Thêm các dòng mã sau vào app/Http/routes.php tập tin và lưu nó.
routes.php
<?php
Route::get('/usercontroller/path',[
'middleware' => 'First',
'uses' => 'UserController@showPath'
]);
Step 2 - Tạo một phần mềm trung gian được gọi là FirstMiddleware bằng cách thực hiện dòng mã sau.
php artisan make:middleware FirstMiddleware
Step 3 - Thêm mã sau vào handle phương thức của FirstMiddleware mới được tạo tại app/Http/Middleware.
FirstMiddleware.php
<?php
namespace App\Http\Middleware;
use Closure;
class FirstMiddleware {
public function handle($request, Closure $next) {
echo '<br>First Middleware';
return $next($request);
}
}
Step 4 - Tạo một phần mềm trung gian được gọi là SecondMiddleware bằng cách thực hiện lệnh sau.
php artisan make:middleware SecondMiddleware
Step 5 - Thêm mã sau vào phương thức xử lý của SecondMiddleware mới được tạo tại app/Http/Middleware.
SecondMiddleware.php
<?php
namespace App\Http\Middleware;
use Closure;
class SecondMiddleware {
public function handle($request, Closure $next) {
echo '<br>Second Middleware';
return $next($request);
}
}
Step 6 - Tạo một bộ điều khiển được gọi là UserController bằng cách thực hiện dòng sau.
php artisan make:controller UserController --plain
Step 7 - Sau khi thực hiện thành công URL, bạn sẽ nhận được kết quả sau:
Step 8 - Sao chép mã sau vào app/Http/UserController.php tập tin.
app/Http/UserController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class UserController extends Controller {
public function __construct() {
$this->middleware('Second');
}
public function showPath(Request $request) {
$uri = $request->path();
echo '<br>URI: '.$uri;
$url = $request->url();
echo '<br>';
echo 'URL: '.$url;
$method = $request->method();
echo '<br>';
echo 'Method: '.$method;
}
}
Step 9 - Bây giờ khởi chạy máy chủ web nội bộ của php bằng cách thực hiện lệnh sau, nếu bạn chưa thực thi.
php artisan serve
Step 10 - Truy cập URL sau.
http://localhost:8000/usercontroller/path
Step 11 - Đầu ra sẽ xuất hiện như trong hình sau.
Bộ điều khiển tài nguyên khôi phục
Thông thường, trong khi tạo ứng dụng, chúng ta cần thực hiện CRUD (Create, Read, Update, Delete)các hoạt động. Laravel làm cho công việc này trở nên dễ dàng với chúng tôi. Chỉ cần tạo một bộ điều khiển và Laravel sẽ tự động cung cấp tất cả các phương thức cho các hoạt động CRUD. Bạn cũng có thể đăng ký một tuyến duy nhất cho tất cả các phương thức trong tệp route.php.
Thí dụ
Step 1 - Tạo một bộ điều khiển được gọi là MyController bằng cách thực hiện lệnh sau.
php artisan make:controller MyController
Step 2 - Thêm mã sau vào
app/Http/Controllers/MyController.php tập tin.
app/Http/Controllers/MyController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class MyController extends Controller {
public function index() {
echo 'index';
}
public function create() {
echo 'create';
}
public function store(Request $request) {
echo 'store';
}
public function show($id) {
echo 'show';
}
public function edit($id) {
echo 'edit';
}
public function update(Request $request, $id) {
echo 'update';
}
public function destroy($id) {
echo 'destroy';
}
}
Step 3 - Thêm dòng mã sau vào app/Http/routes.php tập tin.
app/Http/routes.php
Route::resource('my','MyController');
Step 4- Bây giờ chúng tôi đang đăng ký tất cả các phương thức của MyController bằng cách đăng ký một bộ điều khiển với tài nguyên. Dưới đây là bảng các hành động được xử lý bởi bộ điều khiển tài nguyên.
Động từ | Con đường | Hoạt động | Tên tuyến đường |
---|---|---|---|
ĐƯỢC | / my | mục lục | my.index |
ĐƯỢC | / my / create | tạo nên | my.create |
BÀI ĐĂNG | / my | cửa hàng | my.store |
ĐƯỢC | /tôi của tôi} | chỉ | Chương trình của tôi |
ĐƯỢC | / my / {my} / edit | biên tập | my.edit |
PUT / PATCH | /tôi của tôi} | cập nhật | my.update |
XÓA BỎ | /tôi của tôi} | hủy hoại | my.destroy |
Step 5 - Hãy thử thực hiện các URL được hiển thị trong bảng sau.
URL | Sự miêu tả | Hình ảnh đầu ra |
---|---|---|
http: // localhost: 8000 / my | Thực thi phương thức chỉ mục của MyController.php | mục lục |
http: // localhost: 8000 / my / create | Thực thi phương thức tạo MyController.php | tạo nên |
http: // localhost: 8000 / my / 1 | Thực thi hiển thị phương thức của MyController.php | chỉ |
http: // localhost: 8000 / my / 1 / edit | Thực thi phương thức chỉnh sửa của MyController.php | biên tập |
Bộ điều khiển ngầm định
Bộ điều khiển ngầm định cho phép bạn xác định một tuyến đường duy nhất để xử lý mọi hành động trong bộ điều khiển. Bạn có thể xác định nó trong tệp route.php vớiRoute:controller như hình dưới đây.
Route::controller(‘base URI’,’<class-name-of-the-controller>’);
Thay thế <class-name-of-the-controller> bằng tên lớp mà bạn đã đặt cho bộ điều khiển của mình.
Tên phương thức của bộ điều khiển phải bắt đầu bằng động từ HTTP như get hoặc post. Nếu bạn bắt đầu nó với get, nó sẽ chỉ xử lý yêu cầu nhận được và nếu nó bắt đầu với post thì nó sẽ xử lý yêu cầu đăng. Sau động từ HTTP, bạn có thể đặt bất kỳ tên nào cho phương thức nhưng nó phải tuân theo phiên bản trường hợp tiêu đề của URI.
Thí dụ
Step 1- Thực hiện lệnh dưới đây để tạo bộ điều khiển. Chúng tôi đã giữ tên lớpImplicitController. Bạn có thể đặt bất kỳ tên nào bạn chọn cho lớp.
php artisan make:controller ImplicitController --plain
Step 2 - Sau khi thực hiện thành công bước 1, bạn sẽ nhận được kết quả sau:
Step 3 - Sao chép mã sau vào
app/Http/Controllers/ImplicitController.php tập tin.
app/Http/Controllers/ImplicitController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class ImplicitController extends Controller {
/**
* Responds to requests to GET /test
*/
public function getIndex() {
echo 'index method';
}
/**
* Responds to requests to GET /test/show/1
*/
public function getShow($id) {
echo 'show method';
}
/**
* Responds to requests to GET /test/admin-profile
*/
public function getAdminProfile() {
echo 'admin profile method';
}
/**
* Responds to requests to POST /test/profile
*/
public function postProfile() {
echo 'profile method';
}
}
Step 4 - Thêm dòng sau vào app/Http/routes.php tệp để định tuyến các yêu cầu đến bộ điều khiển được chỉ định.
app/Http/routes.php
Route::controller('test','ImplicitController');
Constructor Injection
Vùng chứa dịch vụ Laravel được sử dụng để giải quyết tất cả các bộ điều khiển Laravel. Do đó, bạn có thể gõ gợi ý bất kỳ phụ thuộc nào mà bộ điều khiển của bạn có thể cần trong phương thức khởi tạo của nó. Các phụ thuộc sẽ tự động được giải quyết và đưa vào phiên bản controller.
Thí dụ
Step 1 - Thêm mã sau vào app/Http/routes.php tập tin.
app/Http/routes.php
class MyClass{
public $foo = 'bar';
}
Route::get('/myclass','ImplicitController@index');
Step 2 - Thêm mã sau vào
app/Http/Controllers/ImplicitController.php tập tin.
app/Http/Controllers/ImplicitController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class ImplicitController extends Controller {
private $myclass;
public function __construct(\MyClass $myclass) {
$this->myclass = $myclass;
}
public function index() {
dd($this->myclass);
}
}
Step 3 - Truy cập URL sau để kiểm tra việc chèn hàm tạo.
http://localhost:8000/myclass
Step 4 - Đầu ra sẽ xuất hiện như trong hình sau.
Phương pháp tiêm
Ngoài việc chèn hàm tạo, bạn cũng có thể gõ - gợi ý phụ thuộc vào các phương thức hành động của bộ điều khiển của bạn.
Thí dụ
Step 1 - Thêm mã sau vào app/Http/routes.php tập tin.
app/Http/routes.php
class MyClass{
public $foo = 'bar';
}
Route::get('/myclass','ImplicitController@index');
Step 2 - Thêm mã sau vào
app/Http/Controllers/ImplicitController.php tập tin.
app/Http/Controllers/ImplicitController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
class ImplicitController extends Controller {
public function index(\MyClass $myclass) {
dd($myclass);
}
}
Step 3 - Truy cập URL sau để kiểm tra việc chèn hàm tạo.
http://localhost:8000/myclass
Nó sẽ tạo ra kết quả sau: