Pengawal CakePHP

PHPz
PHPzasal
2024-09-10 17:25:17859semak imbas

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.

AppPengawal 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.

Tindakan Pengawal

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.

Contoh

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.

Mengubah hala

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.

Contoh

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

Output

Setelah pelaksanaan, anda akan menerima output berikut.

Pengawal CakePHP

Sekarang, lawati URL berikut: http://localhost/cakephp4/redirect-controller2

URL di atas akan memberikan anda output berikut.

Pengawal CakePHP

Memuatkan Model

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.

Contoh

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:Penghalaan CakePHPArtikel seterusnya:Penghalaan CakePHP