ホームページ バックエンド開発 PHPチュートリアル Zend Framework チュートリアル フロントエンド コントローラー Zend_Controller_Front の使い方詳細説明、ledcontroller コントローラー

Zend Framework チュートリアル フロントエンド コントローラー Zend_Controller_Front の使い方詳細説明、ledcontroller コントローラー

Jul 12, 2016 am 08:57 AM
framework zend

この記事では、Zend Framework チュートリアルのフロントエンド コントローラー Zend_Controller_Front の使い方を主に紹介しており、フロントエンド コントローラー Zend_Controller_Front の機能、使用方法、および関連する注意事項について詳しく説明しています。必要な方は参考にしてください。 Zend Framework チュートリアルでは、フロントエンド コントローラー Zend_Controller_Front の使用法を説明します。参考までに、以下のように皆さんと共有してください:

主な機能

ZendFramework の MVC 実装の中核メカニズムは、リクエスト環境の初期化、リクエストの処理、ルート配布、 Zend_Controller_Front はシングルトン モードを採用しているため、アプリケーションにはフロントエンド コントローラーが 1 つだけあります。フロントエンド コントローラーに特別な機能を提供する必要がある場合は、Zend_Controller_Front を継承してフロントエンド コントローラーをカスタマイズできます。

Mainメソッド

getInstance()

は、フロントエンドコントローラーインスタンスを取得するために使用されます。フロント コントローラー オブジェクトを作成する唯一の方法。

$front = Zend_Controller_Front::getInstance();
ログイン後にコピー

setControllerDirectory()とaddControllerDirectory()

setControllerDirectory()はアクションコントローラーアクションコントローラークラスファイルの保存場所を設定します。パラメータにはパス文字列または連想配列を使用できます。

例:

//路径是相对于应用的/application目录下
// 字符串
$front->setControllerDirectory('../application/controllers');
// 关联数组
$front->setControllerDirectory(array(
  'default' => '../application/controllers',
  'blog'  => '../modules/blog/controllers',
  'news'  => '../modules/news/controllers',
));
// Add a 'foo' module directory:
$front->addControllerDirectory('../modules/foo/controllers', 'foo');
ログイン後にコピー

注: モジュール名を指定せずに addControllerDirectory() を使用すると、ディレクトリはデフォルトのモジュールに設定されます。ディレクトリが設定されている場合は上書きされます。

コントローラー ディレクトリの現在の設定は、getControllerDirectory() を通じて取得でき、モジュールとディレクトリのペアの連想配列が返されます。

addModuleDirectory() と getModuleDirectory()

フロントエンド コントローラーの機能の 1 つは、モジュール ディレクトリ構造を定義して、「モジュール」と呼ばれる独立したコンポーネントを作成できることです。

各モジュールは独自のディレクトリに配置され、デフォルト モジュールと同じディレクトリ構造を持ちます。たとえば、少なくとも「controllers」サブディレクトリ、「views」サブディレクトリ、およびその他のアプリケーション サブディレクトリがあります。

addModuleDirectory() を使用すると、1 つ以上のモジュール ディレクトリを含むディレクトリ名を渡すことができます。 次に、それらはスキャンされ、コントローラ ディレクトリとしてフロント コントローラに追加されます。

次に、特定のモジュールまたは現在のモジュール パスを確認したい場合は、getModuleDirectory() を呼び出し、オプションでモジュール名を渡してモジュール ディレクトリを取得します。

dispatch()

dispatch(Zend_Controller_Request_Abstract $request = null, Zend_Controller_Response_Abstract $response = null) は、フロントエンド コントローラーの最も重い作業を行います。このメソッドはオプションのパラメータ要求オブジェクトや応答オブジェクトを受け取り、開発者がそれぞれのカスタム オブジェクトを渡すことができます。

リクエストまたはレスポンスオブジェクトが渡されない場合、dispatch()は以前に登録されたオブジェクトをチェックしてそれを使用し、見つからない場合はデフォルトのオブジェクトバージョンを作成します(どちらもデフォルトではHTTPオブジェクトを使用します)。

同様に、dispatch() は最初に登録されたルーターとディスパッチャーのオブジェクトをチェックし、見つからない場合はデフォルト バージョンをインスタンス化します。

配布プロセスには、ルーティング、ディスパッチ、レスポンスという 3 つの異なるイベントがあります。

ルーティングは、dispatch() が呼び出されたときにリクエスト オブジェクトの値を使用して 1 回だけ発生します。配布はループ内で行われます。リクエストは複数のアクションのディスパッチを示す場合があります。また、コントローラーまたはプラグインがリクエスト オブジェクトをリセットして、追加のアクションを強制的にディスパッチする場合もあります。すべてが完了すると、フロント コントローラーは応答オブジェクトを返します。

run()

Zend_Controller_Front::run($path) は、コントローラーを含むディレクトリへのパスであるパラメーターを 1 つだけ持つ静的メソッドです。まず getInstance() を通じてフロントエンド コントローラー インスタンスを取得し、次に setControllerDirectory() を通じて受信パスを登録し、最後にそれを配布します。

基本的に、フロントエンド コントローラー環境をカスタマイズする必要がない場合、run() はフロントエンド コントローラー環境を確立する非常に便利なメソッドです。

Zend_Controller_Front::run('../application/controllers');
ログイン後にコピー

環境アクセサー メソッド

上記のメソッドに加えて、フロントエンド コントローラー環境に影響を与える可能性のあるアクセサー メソッドが多数あり、したがってフロントエンド コントローラーのデリゲート (デリゲート) にも影響を与える可能性があります。クラス環境。

resetInstance() メソッドは、現在の設定をすべてクリアします。主にテストに使用されますが、複数のフロント コントローラーをチェーンする場合にも使用できます。

(set|get)DefaultControllerName() メソッドは、デフォルト コントローラーの別の名前を指定し (それ以外の場合は 'index' を使用)、現在の値を取得できます。彼らはディストリビュータを代理します。

(set|get)DefaultAction() メソッドは、デフォルトのアクションに別の名前を指定し (それ以外の場合は 'index' を使用)、現在の値を取得できます。彼らはディストリビュータを代理します。

(set|get)Request() メソッドは、配信処理で使用されるリクエストのクラスまたはオブジェクトを指定し、現在のリクエスト オブジェクトを取得します。リクエスト オブジェクトを設定するときに、リクエスト クラスの名前を渡すことができます。このメソッドはクラス ファイルをロードしてインスタンスを作成します。

(set|get)Router()方法指定分发过程中使用的路由器类或对象,以及获取当前对象。设置路由器时,可以传入一个路由器类的名字,该方法将加载类文件并创建实例。

获取路由器对象的时候,首先检查是否已有一个,如果没有,创建默认的路由器实例(rewrite路由器)。

(set|get)BaseUrl()方法指定路由请求时剥离(strip)的基地址(base URL),以及获取当前值。这个值将在路由前提供给路由器。

(set|get)Dispatcher()方法指定分发过程中使用的分发器类或对象,以及获取当前对象。设定分发器对象时,可以传入一个分发器类的名字,该方法将加载类文件并创建实例。

获取分发器对象时,首先检查是否已有一个存在,如果没有,将创建一个默认的分发器实例。

(set|get)Response()方法指定分发过程中使用的响应类或对象,已经获取当前对象。设定响应对象时,可以传入一个响应类的名字,该方法将加载类文件并创建实例。

registerPlugin(Zend_Controller_Plugin_Abstract $plugin, $stackIndex = null)方法允许注册一个插件对象。通过设置可选参数$stackIndex,插件执行的顺序。

unregisterPlugin($plugin)方法移除插件对象。$plugin可以是一个插件对象或者代表移除插件类的字符串。

throwExceptions($flag)方法用来开启或者关闭分发过程中抛出异常的能力。默认的,异常引起并放置在响应对象中;开启throwExceptions()将覆盖这一行为。

returnResponse($flag)方法通知前端控制器是否从dispatch()中返回请求对象(true),否则自动发送响应对象(false—)。默认的,响应对象被自动发送(通过调用Zend_Controller_Response_Abstract::sendResponse());开启returnResponse()将覆盖这一行为。

返回响应对象的原因包括希望在发送响应前检查异常,记录响应的各种属性(例如消息头)等等。

前端控制器参数

介绍里曾提到前端控制器可以用作各种控制器组件的注册表。它通过一个"param"家族的方法来做到这些。这些方法允许通过前端控制器注册任意类型的数据 —— 对象和变量,可以在分发链中的任何时候获取。这些变量被传递到路由器,分发器,以及动作控制器。这些方法包括:

setParam($name, $value)方法设定值为$value的单个参数$name。
setParams(array $params)方法通过关联数组一次设定多个参数。
getParam($name)方法通过$name标识符获取单个参数。
getParams()方法一次获取整个参数列表。
clearParams()方法可以清空一个参数(传入单个字符串标识符),清空多个参数(传入字符串标识符数组),清空整个参数栈(不传入参数)。

有几个预定义的参数可供设定,它们在分发链中有特别的用途:

useDefaultControllerAlways用来提示 分发器遇到无法分发的请求时使用默认模块的默认控制器。这默认是关闭的。

阅读可能遭遇的MVC异常获得使用该设定的更详尽信息。

disableOutputBuffering用来提示 is used to hint to 分发器不使用输出缓冲来捕捉动作控制器产生的输出。默认的,分发器捕捉任何输出并追加到响应对象的主体内容。

noViewRenderer用来禁用ViewRenderer。设定该参数为true可以禁用该助手。

noErrorHandler 用来禁用错误处理器插件。设定该参数为true可以禁用该插件。

自定义前端控制器

要继承前端控制器,至少需要覆盖getInstance()方法:

class My_Controller_Front extends Zend_Controller_Front
{
  public static function getInstance()
  {
    if (null === self::$_instance) {
      self::$_instance = new self();
    }
    return self::$_instance;
  }
}
ログイン後にコピー

覆盖getInstance()保证后面调用Zend_Controller_Front::getInstance()会返回子类的实例,而不是Zend_Controller_Front实例,这对于一些可替换的路由器和视图助手非常有用。

通常不需要继承前端控制器,除非你需要增加新的功能(比如,一个插件自动加载器,或者一个方法来指定动作助手路径)。你想要改动的地方可能包括修改控制器目录的存储方式,使用的默认路由器以及分发器。

ZendFramewrok提供的默认前端控制器已经足够我们使用了,通过Bootstrap功能,完全没有必要手动编写代码改变Zend_Controller_Front的默认机制。所以通常情况下Zend_Controller_Front对于应用来说是不存在。如果需要使用Zend_Controller_Front提供的功能,通过Zend_Controller_Front::getInstance();获取实例即可。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Microsoft NET Framework のインストールの問題エラー コード 0x800c0006 の修正 Microsoft NET Framework のインストールの問題エラー コード 0x800c0006 の修正 May 05, 2023 pm 04:01 PM

開発者とエンド ユーザーが Windows 上で最新バージョンのアプリケーションを実行するには、.NET Framework 4 が必要です。しかし、.NET Framework 4 のダウンロードとインストール中に、多くのユーザーから、インストーラーが途中で停止し、「ダウンロードがエラー コード 0x800c0006 で失敗したため、.NET Framework 4 はインストールされていません」というエラー メッセージが表示されるという苦情が寄せられました。デバイスに .NETFramework4 をインストールしているときにもこの問題が発生する場合は、正しい場所にいます。

Windows 11/10 で SetupDiag を使用して Windows アップグレードの問題を特定する方法 Windows 11/10 で SetupDiag を使用して Windows アップグレードの問題を特定する方法 Apr 17, 2023 am 10:07 AM

Windows 11 または Windows 10 PC でアップグレードまたはアップデートの問題が発生すると、通常、失敗の背後にある実際の理由を示すエラー コードが表示されます。ただし、エラー コードが表示されずにアップグレードまたはアップデートが失敗すると、混乱が生じることがあります。便利なエラー コードを使用すると、問題の場所が正確にわかるので、修正を試みることができます。ただし、エラー コードが表示されないため、問題を特定して解決することが困難になります。エラーの背後にある理由を見つけるだけでも多くの時間がかかります。この場合、Microsoft が提供する SetupDiag という専用ツールを使用すると、エラーの背後にある本当の理由を簡単に特定できます。

SCNotification が動作を停止しました [問題を解決する 5 つのステップ] SCNotification が動作を停止しました [問題を解決する 5 つのステップ] May 17, 2023 pm 09:35 PM

Windows ユーザーは、コンピュータを起動するたびに「SCNotification は動作を停止しました」というエラーに遭遇する可能性があります。 SCNotification.exe は Microsoft システム通知ファイルであり、アクセス許可エラーやネットワーク障害が原因で PC を起動するたびにクラッシュします。このエラーは、問題のあるイベント名でも知られています。したがって、これは SCNotification が動作を停止したということではなく、バグ clr20r3 として認識される可能性があります。この記事では、SCNotification が動作を停止した問題を修正して再び悩まされないようにするために必要なすべての手順を説明します。 SCNotification.eとは何ですか

Microsoft .NET Framework 4.5.2、4.6、および 4.6.1 は 2022 年 4 月にサポートを終了します Microsoft .NET Framework 4.5.2、4.6、および 4.6.1 は 2022 年 4 月にサポートを終了します Apr 17, 2023 pm 02:25 PM

Microsoft.NET バージョン 4.5.2、4.6、または 4.6.1 をインストールしている Microsoft Windows ユーザーが、将来の製品更新を通じて Microsoft にフレームワークをサポートさせることを希望する場合は、新しいバージョンの Microsoft Framework をインストールする必要があります。 Microsoft によると、3 つのフレームワークはすべて 2022 年 4 月 26 日にサポートを終了します。サポート期限が終了すると、製品は「セキュリティ修正またはテクニカル サポート」を受けられなくなります。ほとんどのホーム デバイスは、Windows アップデートを通じて最新の状態に保たれます。これらのデバイスには、.NET Framework 4.8 などの新しいバージョンのフレームワークがすでにインストールされています。自動的に更新されないデバイスは、

Windows 11 の KB5012643 により .NET Framework 3.5 アプリが中断される Windows 11 の KB5012643 により .NET Framework 3.5 アプリが中断される May 09, 2023 pm 01:07 PM

Windows 11 に KB5012643 をインストールしたユーザーに影響を与える新しいセーフ モードのバグについてお話ししてから 1 週間が経過しました。このやっかいな問題は、Microsoft が発売日に投稿した既知の問題のリストには載っていなかったので、誰もが驚きました。さて、事態がこれ以上悪化するはずはないと思ったそのとき、Microsoft は、この累積的な更新プログラムをインストールしたユーザーに別の爆弾を投下します。 Windows 11 Build 22000.652 はさらなる問題を引き起こす そこで同社は、Windows 11 ユーザーに対し、一部の .NET Framework 3.5 アプリケーションの起動と使用に問題が発生する可能性があると警告しています。おなじみですね?でも驚かないでください

Zend Framework でのアクセス許可制御に ACL (アクセス コントロール リスト) を使用する方法 Zend Framework でのアクセス許可制御に ACL (アクセス コントロール リスト) を使用する方法 Jul 29, 2023 am 09:24 AM

Zend Framework でのアクセス許可制御に ACL (AccessControlList) を使用する方法 はじめに: Web アプリケーションでは、アクセス許可制御は重要な機能です。これにより、ユーザーはアクセスを許可されたページと機能にのみアクセスできるようになり、不正アクセスが防止されます。 Zend フレームワークは、ACL (AccessControlList) コンポーネントを使用してアクセス許可制御を実装する便利な方法を提供します。この記事では、Zend Framework で ACL を使用する方法を紹介します。

PHP 実装フレームワーク: Zend Framework 入門チュートリアル PHP 実装フレームワーク: Zend Framework 入門チュートリアル Jun 19, 2023 am 08:09 AM

PHP 実装フレームワーク: ZendFramework 入門チュートリアル ZendFramework は、PHP によって開発されたオープン ソースの Web サイト フレームワークであり、現在 ZendTechnologies によって保守されています。ZendFramework は、MVC デザイン パターンを採用し、Web2.0 アプリケーションと Web サーブの実装に役立つ一連の再利用可能なコード ライブラリを提供します。 。 ZendFramework は PHP 開発者に非常に人気があり、尊敬されており、幅広い機能を備えています。

Cooler Master と Framework が、ラップトップのマザーボードと互換性のある革新的なミニケース キットを発売 Cooler Master と Framework が、ラップトップのマザーボードと互換性のある革新的なミニケース キットを発売 Dec 15, 2023 pm 05:35 PM

12月9日のニュースによると、Cooler Masterは最近、台北コンピューティングショーでのデモンストレーションイベントで、ノートブックモジュラーソリューションプロバイダーのFrameworkと協力して、ミニシャーシキットをデモしました。このキットのユニークな点は、マザーボードと互換性があり、マザーボードを取り付けることができることです。フレームワークノートから。現在、この製品は市場で販売が開始されており、価格は39ドル、現在の為替レートで約279元に相当します。このシャーシキットの型番は「frameWORKMAINBOARDCASE」となります。デザイン面では、わずか297x133x15mmという究極のコンパクトさと実用性を実現しています。そのオリジナルのデザインは、フレームワーク ノートブックにシームレスに接続できるようにすることです。

See all articles