CakePHP - ตัวควบคุม

ตัวควบคุมตามชื่อระบุว่าควบคุมแอปพลิเคชัน มันทำหน้าที่เหมือนสะพานเชื่อมระหว่างโมเดลและมุมมอง ตัวควบคุมจัดการกับข้อมูลคำขอตรวจสอบให้แน่ใจว่ามีการเรียกรุ่นที่ถูกต้องและการตอบสนองหรือมุมมองที่ถูกต้องถูกแสดง

มีการเรียกวิธีการในคลาสของคอนโทรลเลอร์ actions. คอนโทรลเลอร์แต่ละตัวทำตามหลักการตั้งชื่อ ชื่อคลาส Controller อยู่ในรูปพหูพจน์ Camel Cased และลงท้ายด้วย Controller -PostsController.

AppController

AppConttrollerคลาสเป็นคลาสหลักของคอนโทรลเลอร์ของแอปพลิเคชันทั้งหมด คลาสนี้ขยายไฟล์Controllerคลาส CakePHP AppController กำหนดไว้ที่src/Controller/AppController.php. ไฟล์มีรหัสต่อไปนี้

<?php
declare(strict_types=1);
namespace App\Controller;
use Cake\Controller\Controller;
class AppController extends Controller {
   public function initialize(): void {
      parent::initialize();
      $this->loadComponent('RequestHandler');
      $this->loadComponent('Flash');
   }
}

AppControllerสามารถใช้เพื่อโหลดส่วนประกอบที่จะใช้ในทุกคอนโทรลเลอร์ของแอปพลิเคชันของคุณ แอตทริบิวต์และวิธีการที่สร้างขึ้นใน AppController จะพร้อมใช้งานในคอนโทรลเลอร์ทั้งหมดที่ขยาย initialize() วิธีการจะถูกเรียกใช้ที่ส่วนท้ายของคอนสตรัคเตอร์ของคอนโทรลเลอร์เพื่อโหลดส่วนประกอบ

การดำเนินการของคอนโทรลเลอร์

วิธีการในคลาสคอนโทรลเลอร์เรียกว่าการดำเนินการ การดำเนินการเหล่านี้มีหน้าที่ในการส่งการตอบสนองที่เหมาะสมสำหรับเบราว์เซอร์ / ผู้ใช้ที่ร้องขอ มุมมองถูกแสดงโดยชื่อของการกระทำเช่นชื่อของวิธีการในตัวควบคุม

ตัวอย่าง

class RecipesController extends AppController {
   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.
   }
}

ดังที่คุณเห็นในตัวอย่างด้านบนไฟล์ RecipesController มี 3 การกระทำ - View, แบ่งปันและ Search.

กำลังเปลี่ยนเส้นทาง

สำหรับการเปลี่ยนเส้นทางผู้ใช้ไปยังการกระทำอื่นของคอนโทรลเลอร์เดียวกันเราสามารถใช้เมธอด setAction () ต่อไปนี้เป็นไวยากรณ์สำหรับเมธอด setAction ()

Cake\Controller\Controller::setAction($action, $args...)

รหัสต่อไปนี้จะเปลี่ยนเส้นทางผู้ใช้ไปยังดัชนีการกระทำของตัวควบคุมเดียวกัน

$this->setAction('index');

ตัวอย่างต่อไปนี้แสดงการใช้งานวิธีการข้างต้น

ตัวอย่าง

ทำการเปลี่ยนแปลงในไฟล์ config/routes.php ตามที่แสดงในโปรแกรมต่อไปนี้

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'=>'Redirects','action'=>'action1']);
   $builder->connect('/redirect-controller2',['controller'=>'Redirects','action'=>'action2']);
   $builder->fallbacks();
});

สร้างไฟล์ RedirectsController.phpไฟล์ที่ src / Controller / RedirectsController.php คัดลอกรหัสต่อไปนี้ในไฟล์คอนโทรลเลอร์

src/Controller/RedirectsController.php

<?php
declare(strict_types=1);
namespace App\Controller;
use Cake\Core\Configure;
use Cake\Http\Exception\ForbiddenException;
use Cake\Http\Exception\NotFoundException;
use Cake\Http\Response;
use Cake\View\Exception\MissingTemplateException;
class RedirectsController extends AppController {
   public function action1() {
   }
   public function action2(){
      echo "redirecting from action2";
      $this->setAction('action1');
   }
}

สร้างไดเร็กทอรี Redirects ที่ src/Template และภายใต้ไดเร็กทอรีนั้นให้สร้างไฟล์ Viewไฟล์ชื่อ action1.php คัดลอกรหัสต่อไปนี้ในไฟล์นั้น

src/Template/Redirects/action1.php

<h1>This is an example of how to redirect within controller.</h1>

ดำเนินการตามตัวอย่างข้างต้นโดยไปที่ URL ต่อไปนี้

http: // localhost / cakephp4 / redirect-controller

เอาต์พุต

เมื่อดำเนินการคุณจะได้รับผลลัพธ์ต่อไปนี้

ตอนนี้ไปที่ URL ต่อไปนี้: http: // localhost / cakephp4 / redirect-controller2

URL ด้านบนจะให้ผลลัพธ์ดังต่อไปนี้

กำลังโหลดโมเดล

ใน CakePHP สามารถโหลดโมเดลได้โดยใช้ไฟล์ loadModel()วิธี. ต่อไปนี้เป็นไวยากรณ์สำหรับloadModel() วิธีการ -

Cake\Controller\Controller::loadModel(string $modelClass, string $type)

มีสองอาร์กิวเมนต์สำหรับฟังก์ชันข้างต้นดังนี้ -

  • อาร์กิวเมนต์แรกคือชื่อของคลาสโมเดล

  • อาร์กิวเมนต์ที่สองคือประเภทของที่เก็บที่จะโหลด

ตัวอย่าง

หากคุณต้องการโหลด Articles model ในคอนโทรลเลอร์คุณสามารถโหลดได้โดยเขียนบรรทัดต่อไปนี้ในการกระทำของคอนโทรลเลอร์

$this->loadModel('Articles');