Laravel - Contrôleurs

Dans le cadre MVC, la lettre «C» signifie Controller. Il agit comme un trafic dirigeant entre les vues et les modèles. Dans ce chapitre, vous découvrirez les contrôleurs de Laravel.

Créer un contrôleur

Ouvrez l'invite de commande ou le terminal en fonction du système d'exploitation que vous utilisez et tapez la commande suivante pour créer un contrôleur à l'aide de l'Artisan CLI (interface de ligne de commande).

php artisan make:controller <controller-name> --plain

Remplacez le <controller-name> par le nom de votre contrôleur. Cela créera un constructeur simple lorsque nous transmettons l'argument -plain. Si vous ne souhaitez pas créer un constructeur simple, vous pouvez simplement ignorer l'argument. Le constructeur créé peut être vu àapp/Http/Controllers.

Vous verrez que certains codages de base ont déjà été effectués pour vous et vous pouvez ajouter votre codage personnalisé. Le contrôleur créé peut être appelé à partir de routes.php par la syntaxe suivante.

Syntaxe

Route::get(‘base URI’,’controller@method’);

Exemple

Step 1 - Exécutez la commande suivante pour créer UserController.

php artisan make:controller UserController --plain

Step 2 - Après une exécution réussie, vous recevrez la sortie suivante.

Step 3 - Vous pouvez voir le contrôleur créé à app/Http/Controller/UserController.php avec un codage de base déjà écrit pour vous et vous pouvez ajouter votre propre codage en fonction de vos besoins.

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;

class UserController extends Controller {
   //
}

Middleware de contrôleur

Nous avons déjà vu le middleware et il peut également être utilisé avec le contrôleur. Le middleware peut également être affecté à la route du contrôleur ou dans le constructeur de votre contrôleur. Vous pouvez utiliser la méthode middleware pour attribuer un middleware au contrôleur. Le middleware enregistré peut également être limité à certaines méthodes du contrôleur.

Attribution d'un middleware au routage

Route::get('profile', [
   'middleware' => 'auth',
   'uses' => 'UserController@showProfile'
]);

Ici, nous attribuons un middleware d'authentification à UserController dans la route de profil.

Attribution d'un middleware dans le constructeur du contrôleur

<?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');
   }
}

Ici, nous attribuons auth middleware utilisant la méthode middleware dans le UserController constructeur.

Exemple

Step 1 - Ajoutez les lignes de code suivantes au app/Http/routes.php fichier et enregistrez-le.

routes.php

<?php
Route::get('/usercontroller/path',[
   'middleware' => 'First',
   'uses' => 'UserController@showPath'
]);

Step 2 - Créez un middleware appelé FirstMiddleware en exécutant la ligne de code suivante.

php artisan make:middleware FirstMiddleware

Step 3 - Ajoutez le code suivant dans le handle méthode du FirstMiddleware nouvellement créé à 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 - Créez un middleware appelé SecondMiddleware en exécutant la commande suivante.

php artisan make:middleware SecondMiddleware

Step 5 - Ajoutez le code suivant dans la méthode handle du SecondMiddleware nouvellement créé à 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 - Créez un contrôleur appelé UserController en exécutant la ligne suivante.

php artisan make:controller UserController --plain

Step 7 - Après l'exécution réussie de l'URL, vous recevrez la sortie suivante -

Step 8 - Copiez le code suivant dans app/Http/UserController.php fichier.

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 - Lancez maintenant le serveur Web interne de php en exécutant la commande suivante, si vous ne l'avez pas encore exécutée.

php artisan serve

Step 10 - Visitez l'URL suivante.

http://localhost:8000/usercontroller/path

Step 11 - La sortie apparaîtra comme indiqué dans l'image suivante.

Contrôleurs de ressources reposantes

Souvent, lors de la création d'une application, nous devons effectuer CRUD (Create, Read, Update, Delete)opérations. Laravel nous facilite ce travail. Créez simplement un contrôleur et Laravel fournira automatiquement toutes les méthodes pour les opérations CRUD. Vous pouvez également enregistrer une seule route pour toutes les méthodes dans le fichier routes.php.

Exemple

Step 1 - Créez un contrôleur appelé MyController en exécutant la commande suivante.

php artisan make:controller MyController

Step 2 - Ajoutez le code suivant dans

app/Http/Controllers/MyController.php fichier.

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 - Ajoutez la ligne de code suivante dans app/Http/routes.php fichier.

app/Http/routes.php

Route::resource('my','MyController');

Step 4- Nous enregistrons maintenant toutes les méthodes de MyController en enregistrant un contrôleur avec une ressource. Vous trouverez ci-dessous le tableau des actions gérées par le contrôleur de ressources.

Verbe Chemin action Nom de la route
AVOIR /mon indice mon.index
AVOIR / mon / créer créer my.create
PUBLIER /mon boutique Mon magasin
AVOIR /Oh la la} spectacle mon émission
AVOIR / mon / {mon} / modifier Éditer ma rédaction
PUT / PATCH /Oh la la} mettre à jour my.update
EFFACER /Oh la la} détruire mon.destroy

Step 5 - Essayez d'exécuter les URL indiquées dans le tableau suivant.

URL La description Image de sortie
http: // localhost: 8000 / mon Exécute la méthode d'index de MyController.php indice
http: // localhost: 8000 / my / create Exécute la méthode de création de MyController.php créer
http: // localhost: 8000 / mon / 1 Exécute la méthode show de MyController.php spectacle
http: // localhost: 8000 / mon / 1 / modifier Exécute la méthode d'édition de MyController.php Éditer

Contrôleurs implicites

Les contrôleurs implicites vous permettent de définir une seule route pour gérer chaque action dans le contrôleur. Vous pouvez le définir dans le fichier route.php avecRoute:controller méthode comme indiqué ci-dessous.

Route::controller(‘base URI’,’<class-name-of-the-controller>’);

Remplacez <class-name-of-the-controller> par le nom de classe que vous avez donné à votre contrôleur.

Le nom de la méthode du contrôleur doit commencer par le verbe HTTP comme get ou post. Si vous le démarrez avec get, il ne gérera que la requête get et s'il commence par post, il gérera la demande de publication. Après le verbe HTTP, vous pouvez donner n'importe quel nom à la méthode, mais il doit suivre la version casse de titre de l'URI.

Exemple

Step 1- Exécutez la commande ci-dessous pour créer un contrôleur. Nous avons conservé le nom de la classeImplicitController. Vous pouvez donner n'importe quel nom de votre choix à la classe.

php artisan make:controller ImplicitController --plain

Step 2 - Après l'exécution réussie de l'étape 1, vous recevrez la sortie suivante -

Step 3 - Copiez le code suivant dans

app/Http/Controllers/ImplicitController.php fichier.

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 - Ajoutez la ligne suivante à app/Http/routes.php fichier pour acheminer les demandes vers le contrôleur spécifié.

app/Http/routes.php

Route::controller('test','ImplicitController');

Injection de constructeur

Le conteneur de service Laravel est utilisé pour résoudre tous les contrôleurs Laravel. Par conséquent, vous êtes en mesure d'indiquer de type toutes les dépendances dont votre contrôleur peut avoir besoin dans son constructeur. Les dépendances seront automatiquement résolues et injectées dans l'instance de contrôleur.

Exemple

Step 1 - Ajoutez le code suivant à app/Http/routes.php fichier.

app/Http/routes.php

class MyClass{
   public $foo = 'bar';
}
Route::get('/myclass','ImplicitController@index');

Step 2 - Ajoutez le code suivant à

app/Http/Controllers/ImplicitController.php fichier.

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 - Visitez l'URL suivante pour tester l'injection du constructeur.

http://localhost:8000/myclass

Step 4 - La sortie apparaîtra comme indiqué dans l'image suivante.

Injection de méthode

En plus de l'injection de constructeur, vous pouvez également taper - hint des dépendances sur les méthodes d'action de votre contrôleur.

Exemple

Step 1 - Ajoutez le code suivant à app/Http/routes.php fichier.

app/Http/routes.php

class MyClass{
   public $foo = 'bar';
}
Route::get('/myclass','ImplicitController@index');

Step 2 - Ajoutez le code suivant à

app/Http/Controllers/ImplicitController.php fichier.

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 - Visitez l'URL suivante pour tester l'injection du constructeur.

http://localhost:8000/myclass

Il produira la sortie suivante -