이름에서 알 수 있듯이 컨트롤러는 애플리케이션을 제어합니다. 모델과 뷰 사이의 다리 역할을 합니다. 컨트롤러는 요청 데이터를 처리하고 올바른 모델이 호출되고 올바른 응답 또는 뷰가 렌더링되는지 확인합니다.
컨트롤러 클래스의 메서드를 액션이라고 합니다. 각 컨트롤러는 명명 규칙을 따릅니다. CakePHP 컨트롤러 클래스 이름은 Camel Cased라는 복수형이며 CakePHP 컨트롤러 — PostsCakePHP 컨트롤러.
로 끝납니다.AppConttroller 클래스는 모든 애플리케이션 컨트롤러의 상위 클래스입니다. 이 클래스는 CakePHP의 CakePHP 컨트롤러 클래스를 확장합니다. AppCakePHP 컨트롤러는 src/CakePHP 컨트롤러/AppCakePHP 컨트롤러.php에 정의되어 있습니다. 파일에는 다음 코드가 포함되어 있습니다.
<?php declare(strict_types=1); namespace App\CakePHP 컨트롤러; use Cake\CakePHP 컨트롤러\CakePHP 컨트롤러; class AppCakePHP 컨트롤러 extends CakePHP 컨트롤러 { public function initialize(): void { parent::initialize(); $this->loadComponent('RequestHandler'); $this->loadComponent('Flash'); } }
AppCakePHP 컨트롤러는 애플리케이션의 모든 컨트롤러에서 사용될 구성 요소를 로드하는 데 사용할 수 있습니다. AppCakePHP 컨트롤러에서 생성된 속성과 메서드는 AppCakePHP 컨트롤러를 확장하는 모든 컨트롤러에서 사용할 수 있습니다. initialize() 메소드는 구성요소를 로드하기 위해 컨트롤러 생성자의 끝에서 호출됩니다.
컨트롤러 클래스의 메소드를 액션이라고 합니다. 이러한 작업은 요청을 하는 브라우저/사용자에게 적절한 응답을 보내는 역할을 합니다. 뷰는 액션 이름, 즉 컨트롤러의 메소드 이름으로 렌더링됩니다.
class RecipesCakePHP 컨트롤러 extends AppCakePHP 컨트롤러 { 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. } }
위의 예에서 볼 수 있듯이 RecipesCakePHP 컨트롤러에는 보기, 공유, 검색의 3가지 작업이 있습니다.
사용자를 동일한 컨트롤러의 다른 작업으로 리디렉션하려면 setAction() 메서드를 사용할 수 있습니다. 다음은 setAction() 메소드의 구문입니다.
Cake\CakePHP 컨트롤러\CakePHP 컨트롤러::setAction($action, $args...)
다음 코드는 사용자를 동일한 컨트롤러의 index 작업으로 리디렉션합니다.
$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'=>'CakePHP 컨트롤러s','action'=>'action1']); $builder->connect('/redirect-controller2',['controller'=>'CakePHP 컨트롤러s','action'=>'action2']); $builder->fallbacks(); });
src/CakePHP 컨트롤러/CakePHP 컨트롤러sCakePHP 컨트롤러.php에 CakePHP 컨트롤러sCakePHP 컨트롤러.php 파일을 만듭니다. 컨트롤러 파일에 다음 코드를 복사하세요.
src/CakePHP 컨트롤러/CakePHP 컨트롤러sCakePHP 컨트롤러.php
<?php declare(strict_types=1); namespace App\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 CakePHP 컨트롤러sCakePHP 컨트롤러 extends AppCakePHP 컨트롤러 { public function action1() { } public function action2(){ echo "redirecting from action2"; $this->setAction('action1'); } }
src/Template에 CakePHP 컨트롤러s 디렉터리를 만들고 해당 디렉터리 아래에 action1.php라는 View 파일을 만듭니다. 해당 파일에 다음 코드를 복사하세요.
src/Template/CakePHP 컨트롤러s/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\CakePHP 컨트롤러\CakePHP 컨트롤러::loadModel(string $modelClass, string $type)
위 함수에는 다음과 같은 두 가지 인수가 있습니다. −
첫 번째 인수는 모델 클래스의 이름입니다.
두 번째 인수는 로드할 저장소 유형입니다.
Articles 모델을 컨트롤러에 로드하려면 컨트롤러 액션에 다음 줄을 작성하여 로드할 수 있습니다.
$this->loadModel('Articles');
위 내용은 CakePHP 컨트롤러의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!