Pengawal seperti yang ditunjukkan oleh nama mengawal aplikasi. Ia bertindak seperti jambatan antara model dan pandangan. Pengawal mengendalikan data permintaan, memastikan model yang betul dipanggil dan respons atau pandangan yang betul diberikan.
Kaedah dalam kelas pengawal dipanggil tindakan. Setiap pengawal mengikut konvensyen penamaan. Nama kelas Pengawal adalah dalam bentuk jamak, Camel Cased, dan berakhir dengan Pengawal CakePHP — PostsPengawal CakePHP.
Kelas AppConttroller ialah kelas induk bagi semua pengawal aplikasi. Kelas ini memanjangkan kelas Pengawal CakePHP. AppPengawal CakePHP ditakrifkan di src/Pengawal CakePHP/AppPengawal CakePHP.php. Fail mengandungi kod berikut.
<?php declare(strict_types=1); namespace App\Pengawal CakePHP; use Cake\Pengawal CakePHP\Pengawal CakePHP; class AppPengawal CakePHP extends Pengawal CakePHP { public function initialize(): void { parent::initialize(); $this->loadComponent('RequestHandler'); $this->loadComponent('Flash'); } }
AppPengawal CakePHP boleh digunakan untuk memuatkan komponen yang akan digunakan dalam setiap pengawal aplikasi anda. Atribut dan kaedah yang dibuat dalam AppPengawal CakePHP akan tersedia dalam semua pengawal yang memanjangkannya. Kaedah initialize() akan digunakan pada penghujung pembina pengawal untuk memuatkan komponen.
Kaedah dalam kelas pengawal dipanggil Tindakan. Tindakan ini bertanggungjawab untuk menghantar respons yang sesuai untuk penyemak imbas/pengguna yang membuat permintaan. Paparan diberikan dengan nama tindakan, iaitu, nama kaedah dalam pengawal.
class RecipesPengawal CakePHP extends AppPengawal CakePHP { public function view($id) { // Action logic goes here. } public function share($customerId, $recipeId) { // Action logic goes here. } public function search($query) { // Action logic goes here. } }
Seperti yang anda lihat dalam contoh di atas, RecipesPengawal CakePHP mempunyai 3 tindakan − Lihat, Kongsi dan Cari.
Untuk mengubah hala pengguna ke tindakan lain pengawal yang sama, kami boleh menggunakan kaedah setAction(). Berikut ialah sintaks untuk kaedah setAction().
Cake\Pengawal CakePHP\Pengawal CakePHP::setAction($action, $args...)
Kod berikut akan mengubah hala pengguna ke tindakan indeks pengawal yang sama.
$this->setAction('index');
Contoh berikut menunjukkan penggunaan kaedah di atas.
Buat perubahan dalam fail config/routes.php seperti yang ditunjukkan dalam program berikut.
config/routes.php
<?php use Cake\Http\Middleware\CsrfProtectionMiddleware; use Cake\Routing\Route\DashedRoute; use Cake\Routing\RouteBuilder; $routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { // Register scoped middleware for in scopes. $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf'); $builder->connect('/redirect-controller',['controller'=>'Pengawal CakePHPs','action'=>'action1']); $builder->connect('/redirect-controller2',['controller'=>'Pengawal CakePHPs','action'=>'action2']); $builder->fallbacks(); });
Buat fail Pengawal CakePHPsPengawal CakePHP.php di src/Pengawal CakePHP/Pengawal CakePHPsPengawal CakePHP.php. Salin kod berikut dalam fail pengawal.
src/Pengawal CakePHP/Pengawal CakePHPsPengawal CakePHP.php
<?php declare(strict_types=1); namespace App\Pengawal CakePHP; use Cake\Core\Configure; use Cake\Http\Exception\ForbiddenException; use Cake\Http\Exception\NotFoundException; use Cake\Http\Response; use Cake\View\Exception\MissingTemplateException; class Pengawal CakePHPsPengawal CakePHP extends AppPengawal CakePHP { public function action1() { } public function action2(){ echo "redirecting from action2"; $this->setAction('action1'); } }
Buat direktori Ubah hala di src/Template dan di bawah direktori itu cipta fail View yang dipanggil action1.php. Salin kod berikut dalam fail itu.
src/Template/Pengawal CakePHPs/action1.php
<h1>This is an example of how to redirect within controller.</h1>
Laksanakan contoh di atas dengan melawati URL berikut.
http://localhost/cakephp4/redirect-controller
Setelah pelaksanaan, anda akan menerima output berikut.
Sekarang, lawati URL berikut: http://localhost/cakephp4/redirect-controller2
URL di atas akan memberikan anda output berikut.
Dalam CakePHP, model boleh dimuatkan menggunakan kaedah loadModel(). Berikut ialah sintaks untuk kaedah loadModel() −
Cake\Pengawal CakePHP\Pengawal CakePHP::loadModel(string $modelClass, string $type)
Terdapat dua hujah untuk fungsi di atas seperti berikut −
Argumen pertama ialah nama kelas model.
Argumen kedua ialah jenis repositori untuk dimuatkan.
Jika anda ingin memuatkan model Artikel dalam pengawal, maka model itu boleh dimuatkan dengan menulis baris berikut dalam tindakan pengawal.
$this->loadModel('Articles');
Atas ialah kandungan terperinci Pengawal CakePHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!