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: