コントローラーはその名の通りアプリケーションを制御します。これはモデルとビューの間の橋渡しのように機能します。コントローラーはリクエスト データを処理し、正しいモデルが呼び出され、正しい応答またはビューがレンダリングされることを確認します。
コントローラーのクラスのメソッドは、アクションと呼ばれます。各コントローラーは命名規則に従います。コントローラー クラス名は複数形のキャメルケースで、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 id="This-is-an-example-of-how-to-redirect-within-controller">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)
上記の関数には次の 2 つの引数があります -
最初の引数はモデルクラスの名前です。
2 番目の引数は、ロードするリポジトリのタイプです。
例
記事モデルをコントローラーにロードしたい場合は、コントローラーのアクションに次の行を記述することでロードできます。
$this->loadModel('Articles');
以上がCakePHP コントローラーの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

PHPでは、特性は方法が必要な状況に適していますが、継承には適していません。 1)特性により、クラスの多重化方法が複数の継承の複雑さを回避できます。 2)特性を使用する場合、メソッドの競合に注意を払う必要があります。メソッドの競合は、代替およびキーワードとして解決できます。 3)パフォーマンスを最適化し、コードメンテナビリティを改善するために、特性の過剰使用を避け、その単一の責任を維持する必要があります。

依存関係噴射コンテナ(DIC)は、PHPプロジェクトで使用するオブジェクト依存関係を管理および提供するツールです。 DICの主な利点には、次のものが含まれます。1。デカップリング、コンポーネントの独立したもの、およびコードの保守とテストが簡単です。 2。柔軟性、依存関係を交換または変更しやすい。 3.テスト可能性、単体テストのために模擬オブジェクトを注入するのに便利です。

SplfixedArrayは、PHPの固定サイズの配列であり、高性能と低いメモリの使用が必要なシナリオに適しています。 1)動的調整によって引き起こされるオーバーヘッドを回避するために、作成時にサイズを指定する必要があります。 2)C言語アレイに基づいて、メモリと高速アクセス速度を直接動作させます。 3)大規模なデータ処理とメモリに敏感な環境に適していますが、サイズが固定されているため、注意して使用する必要があります。

PHPは、$ \ _ファイル変数を介してファイルのアップロードを処理します。セキュリティを確保するための方法には次のものが含まれます。1。アップロードエラー、2。ファイルの種類とサイズを確認する、3。ファイル上書きを防ぐ、4。ファイルを永続的なストレージの場所に移動します。

JavaScriptでは、nullcoalescingoperator(??)およびnullcoalescingsignmentoperator(?? =)を使用できます。 1.??最初の非潜水金または非未定されたオペランドを返します。 2.??これらの演算子は、コードロジックを簡素化し、読みやすさとパフォーマンスを向上させます。

XSS攻撃を防ぎ、リソースのロードを制限し、ウェブサイトのセキュリティを改善できるため、CSPは重要です。 1.CSPはHTTP応答ヘッダーの一部であり、厳格なポリシーを通じて悪意のある行動を制限します。 2。基本的な使用法は、同じ起源からのロードリソースのみを許可することです。 3.高度な使用法は、特定のドメイン名がスクリプトやスタイルをロードできるようにするなど、より微調整された戦略を設定できます。 4。CSPポリシーをデバッグおよび最適化するには、コンテンツセキュリティポリシーレポートのみのヘッダーを使用します。

HTTPリクエストメソッドには、それぞれリソースを取得、送信、更新、削除するために使用されるGET、POST、PUT、および削除が含まれます。 1. GETメソッドは、リソースを取得するために使用され、読み取り操作に適しています。 2. POSTメソッドはデータの送信に使用され、新しいリソースを作成するためによく使用されます。 3. PUTメソッドは、リソースの更新に使用され、完全な更新に適しています。 4.削除メソッドは、リソースの削除に使用され、削除操作に適しています。

HTTPSは、HTTPに基づいてセキュリティレイヤーを追加するプロトコルであり、主に暗号化されたデータを介してユーザーのプライバシーとデータセキュリティを保護します。その作業原則には、TLSの握手、証明書の確認、暗号化された通信が含まれます。 HTTPSを実装する場合、証明書管理、パフォーマンスへの影響、および混合コンテンツの問題に注意を払う必要があります。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SublimeText3 中国語版
中国語版、とても使いやすい

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ホットトピック



