CakePHP コントローラー

PHPz
リリース: 2024-09-10 17:25:17
オリジナル
872 人が閲覧しました

コントローラーはその名の通りアプリケーションを制御します。これはモデルとビューの間の橋渡しのように機能します。コントローラーはリクエスト データを処理し、正しいモデルが呼び出され、正しい応答またはビューがレンダリングされることを確認します。

コントローラーのクラスのメソッドは、アクションと呼ばれます。各コントローラーは命名規則に従います。コントローラー クラス名は複数形のキャメルケースで、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 コントローラー で作成された属性とメソッドは、それを拡張するすべてのコントローラーで使用できます。 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 コントローラー には、View、Share、Search の 3 つのアクションがあります。

リダイレクト

ユーザーを同じコントローラーの別のアクションにリダイレクトするには、setAction() メソッドを使用できます。以下は、setAction() メソッドの構文です。

Cake\CakePHP コントローラー\CakePHP コントローラー::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'=>'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

出力

実行すると、次の出力が表示されます。

CakePHP コントローラー

次に、次の URL にアクセスします: http://localhost/cakephp4/redirect-controller2

上記の URL では次の出力が得られます。

CakePHP コントローラー

モデルの読み込み

CakePHP では、loadModel() メソッドを使用してモデルをロードできます。以下は、loadModel() メソッド -

の構文です。
Cake\CakePHP コントローラー\CakePHP コントローラー::loadModel(string $modelClass, string $type)
ログイン後にコピー

上記の関数には次の 2 つの引数があります -

  • 最初の引数はモデルクラスの名前です。

  • 2 番目の引数は、ロードするリポジトリのタイプです。

記事モデルをコントローラーにロードしたい場合は、コントローラーのアクションに次の行を記述することでロードできます。

$this->loadModel('Articles');
ログイン後にコピー

以上がCakePHP コントローラーの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート