Symfony2ルートアノテーションを開始します
コアポイント
- Symfony2のSensioframeworkextrabundleを使用すると、開発者は注釈を使用してコントローラーに直接構成をルーティングし、便利な代替手段を提供します。 Symfony2でのルーティング注釈のルーティングは、ルーティング構成をよりモジュール化し、各ルートは対応するコントローラー操作で直接定義され、コードの理解と保守を容易にします。
- アノテーションにより、URLデフォルトパラメーターの設定、要件の追加、HTTPメソッドまたはスキームの実施、ホスト名の実施など、詳細なルーティング構成が可能になります。
- アノテーションを使用すると、ルーティング構成が含まれるため、コントローラー操作がより複雑になる場合がありますが、これはルーティングをシンプルで十分に文書化することで軽減できます。
- 標準のSymfony 2分布には、Sensioframeworkextrabundleと呼ばれる実用的なバンドルが含まれています。これは、多くの強力な機能、特にコントローラーで直接注釈を使用する機能を実装しています。
この記事は、コントローラー構成の便利な代替品を導入することを目的としており、注釈の必須の方法ではありません。最良のアプローチは、特定のシナリオ要件に依存します。
Symfony 2は、強力な組み込みコンポーネントを使用してアプリケーション用のすべてのルーティングを管理しています:ルーティングコンポーネント。基本的に、ルートはURLをコントローラーアクションにマッピングします。 Symfonyはモジュール式になるように設計されているため、ファイルはこれに特別にセットアップされています:
にあります。
routing.yml
app > config > routing.yml
注釈を使用してルートを定義する方法を理解するには、簡単なブログアプリケーションを例に取りましょう。
ステップ1:ホームページルートを作成します
パスをの操作にリンクします。
注釈方法 /
HomeController
in
in
:
app/config/routing.yml
blog_front_homepage: path : / defaults: { _controller: BlogFrontBundle:Home:index }
ルーティング構成を宣言します。コントローラー自体は、特別な設定を必要としません。 src/Blog/FrontBundle/Controller/HomeController.php
<?php namespace Blog\FrontBundle\Controller; class HomeController { public function indexAction() { //... 创建并返回一个 Response 对象 } }
in routing.yml
:blog_front_homepage
in :
app/config/routing.yml
センター:
resource
コントローラーを指定して に影響します
type
ルートを宣言する方法を定義しますprefix
コントローラークラスのすべての操作のプレフィックスを定義します(オプション)
。 use SensioBundleFrameworkExtraBundleConfigurationRoute;
@Route("/", name="blog_homepage")
「ルーティングレイヤーでコントローラーを上書きする方法を知っているので、少なくとも同じ結果を得るには、より多くのコードが必要です。」
注釈方法
in
:
app/config/routing.yml
blog_front_homepage: path : / defaults: { _controller: BlogFrontBundle:Home:index }
src/Blog/FrontBundle/Controller/HomeController.php
<?php namespace Blog\FrontBundle\Controller; class HomeController { public function indexAction() { //... 创建并返回一个 Response 对象 } }
in :
in app/config/routing.yml
:
blog_front: resource: "@BlogFrontBundle/Controller/" type: annotation prefix: /
注:src/Blog/FrontBundle/Controller/HomeController.php
変更は必要ありません。これで、どの操作がルーティングモードから呼び出されているかを見ることができます。
<?php namespace Blog\FrontBundle\Controller; use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; class HomeController { /** * @Route("/", name="blog_home_index") */ public function indexAction() { /* ... */ } }
などのコントローラー内のすべての操作をプレフィックスする必要がある場合は、routing.yml
キーを
を追加できます。 >
/admin
in routing.yml
:prefix
@Route
:app/config/routing.yml
blog_front_homepage: path : / defaults: { _controller: BlogFrontBundle:Home:index } blog_front_article: path : /article/{slug} defaults: { _controller: BlogFrontBundle:Home:showArticle }
ステップ3:追加のルーティング構成src/Blog/AdminBundle/Controller/AdminController.php
<?php // namespace & uses... class HomeController { public function indexAction() { /* ... */ } public function showArticleAction($slug) { /* ... */ } }
urlデフォルトパラメーターを設定
化学:。
プレースホルダーは、defaults = { "key" = "value" }
キーに
blog_front: resource: "@BlogFrontBundle/Controller/" type: annotation prefix: /
パラメーターの値はslug
に設定されます。また、urldefaults
は、{slug}
パラメーターの値を/article
に一致させて設定します。 slug
hello
/blog/world
要件を追加page
world
。
の値を明確に定義できます。次の例では、数字でまったく同じことを行います。
requirements = { "key" = "value" }
<?php // namespace & uses... class HomeController { /** * @Route("/", name="blog_home_index") */ public function indexAction() { /* ... */ } /** * @Route("/article/{slug}", name="blog_home_show_article") */ public function showArticleAction($slug) { /* ... */ } }
slug
を施行します
{slug}
化学:
blog_front: ... blog_admin: resource: "@BlogAdminBundle/Controller/" type: annotation
blog_front_homepage: path : / defaults: { _controller: BlogFrontBundle:Home:index }
着信要求の方法(Get、Post、Put、Deleteなど)に応じて一致させることもできます。メソッドが指定されていない場合、ルートは任意の方法と一致することに注意してください。
httpソリューション
を施行します化学:schemes = { "protocol" }
。
<?php namespace Blog\FrontBundle\Controller; class HomeController { public function indexAction() { //... 创建并返回一个 Response 对象 } }
この場合、HTTPSプロトコルを介してルートにアクセスされるようにします。
HostName
を執行します化学:host = "myhost.com"
。
blog_front: resource: "@BlogFrontBundle/Controller/" type: annotation prefix: /
HTTPホストに基づいて一致させることもできます。これは、ホストがmyblog.com
の場合にのみ一致します。
ステップ4:練習
AdminController.php
で記事を削除するために正しいルートを作成する必要があると仮定して、信頼できるルーティング構造を構築できます。必要なのは
- パスを
/admin/delete/article/{id}
を定義します 名前を - ;
blog_admin_delete_article
キーの要件を数値のみとして定義します
- GETリクエストメソッドを定義します。
id
- 答えは次のとおりです
最終的な考え
<?php namespace Blog\FrontBundle\Controller; use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; class HomeController { /** * @Route("/", name="blog_home_index") */ public function indexAction() { /* ... */ } }
ご覧のとおり、注釈を使用したルーティングを管理することは簡単に書き込み、読み取り、維持できます。また、コントラクラスの1つのファイルにコードと構成の両方を集中させるという利点もあります。 注釈または標準構成を使用していますか?どちらが好きですか、そしてその理由は何ですか?
symfony2ルーティングアノテーションFAQ(FAQ)(コンテンツのこの部分は擬似オリジナルの目標と一致せず、長すぎるため、FAQの部分はここで省略されています。
以上がSymfony2ルートアノテーションを開始しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

セッションハイジャックは、次の手順で達成できます。1。セッションIDを取得します。2。セッションIDを使用します。3。セッションをアクティブに保ちます。 PHPでのセッションハイジャックを防ぐための方法には次のものが含まれます。1。セッション_regenerate_id()関数を使用して、セッションIDを再生します。2。データベースを介してストアセッションデータを3。

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

phpstormでCLIモードをデバッグする方法は? PHPStormで開発するときは、PHPをコマンドラインインターフェイス(CLI)モードでデバッグする必要がある場合があります。

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。
