Heim >Backend-Entwicklung >PHP-Tutorial >Erste Schritte mit Symfony2 Routenanmerkungen
Kernpunkte
Die Standard -Symfony 2 -Verteilung enthält ein praktisches Bündel namens SensioFrameWorkextrabundle, das viele leistungsstarke Merkmale implementiert, insbesondere die Fähigkeit, Annotationen direkt im Controller zu verwenden.
Dieser Artikel zielt darauf ab, eine bequeme Alternative zur Controller -Konfiguration einzuführen, und ist keine obligatorische Art der Annotation. Der beste Ansatz hängt von den spezifischen Szenarioanforderungen ab.
Symfony 2 verwaltet alle Routing für Anwendungen mit leistungsstarken integrierten Komponenten: Routing-Komponenten. Grundsätzlich ordnet die Route die URL der Controller -Aktion ab. Da Symfony so ausgelegt ist, dass sie modular sind, ist eine Datei speziell dafür eingerichtet: routing.yml
, befindet sich in app > config > routing.yml
.
Um zu verstehen, wie Routen mit Annotationen definiert werden, nehmen wir eine einfache Blog -Anwendung als Beispiel.
Schritt 1: Erstellen Sie eine Startroute
Wir verknüpfen den Pfad mit einer Operation von /
. HomeController
Keine Annotationsmethode
in: app/config/routing.yml
<code class="language-yaml">blog_front_homepage: path : / defaults: { _controller: BlogFrontBundle:Home:index }</code>in
: src/Blog/FrontBundle/Controller/HomeController.php
<code class="language-php"><?php namespace Blog\FrontBundle\Controller; class HomeController { public function indexAction() { //... 创建并返回一个 Response 对象 } }</code>In
deklarieren wir eine einfache routing.yml
Routing -Konfiguration mit zwei Parametern: dem Pfad und dem zu befindlichen Controller -Vorgang. Der Controller selbst erfordert keine speziellen Einstellungen. blog_front_homepage
Verwenden Sie Annotationen
in: app/config/routing.yml
<code class="language-yaml">blog_front: resource: "@BlogFrontBundle/Controller/" type: annotation prefix: /</code>in
: src/Blog/FrontBundle/Controller/HomeController.php
<code class="language-php"><?php namespace Blog\FrontBundle\Controller; use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; class HomeController { /** * @Route("/", name="blog_home_index") */ public function indexAction() { /* ... */ } }</code>
Zentrum: routing.yml
resource
Geben Sie den Controller an, um type
Definieren Sie, wie Routen prefix
Präfixe für alle Vorgänge in der Controller -Klasse (optional)
use SensioBundleFrameworkExtraBundleConfigurationRoute;
Wichtiger ist, wie der Controller erstellt wird. Zunächst müssen wir die relevante Klasse von sensioFrameWorkExtrabundle anrufen: @Route("/", name="blog_homepage")
. Dann können wir die Route und ihre Parameter implementieren: hier nur der Pfad und der Name (wir werden alle Operationen sehen, die später ausgeführt werden können):
Man könnte denken: "Wir wissen, wie man den Controller mit der Routing -Ebene überschreibt. Was ist also der Punkt? Letztendlich wird mehr Code benötigt, um das gleiche Ergebnis zu erzielen."
Schritt 2: Artikelseitenroute hinzufügen
Keine Annotationsmethode
app/config/routing.yml
in
<code class="language-yaml">blog_front_homepage: path : / defaults: { _controller: BlogFrontBundle:Home:index }</code>
src/Blog/FrontBundle/Controller/HomeController.php
in
<code class="language-php"><?php namespace Blog\FrontBundle\Controller; class HomeController { public function indexAction() { //... 创建并返回一个 Response 对象 } }</code>
Verwenden Sie Annotationen
app/config/routing.yml
in
<code class="language-yaml">blog_front: resource: "@BlogFrontBundle/Controller/" type: annotation prefix: /</code>
src/Blog/FrontBundle/Controller/HomeController.php
in
<code class="language-php"><?php namespace Blog\FrontBundle\Controller; use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; class HomeController { /** * @Route("/", name="blog_home_index") */ public function indexAction() { /* ... */ } }</code>
routing.yml
Hinweis:
/admin
Wenn Sie möchten, dass alle Vorgänge im Controller vorangestellt werden, z. B. routing.yml
, können Sie die prefix
-Taste von @Route
entfernen und zum oberen Rand der Klassennote ein zusätzliches
app/config/routing.yml
in
<code class="language-yaml">blog_front_homepage: path : / defaults: { _controller: BlogFrontBundle:Home:index } blog_front_article: path : /article/{slug} defaults: { _controller: BlogFrontBundle:Home:showArticle }</code>
src/Blog/AdminBundle/Controller/AdminController.php
in
<code class="language-php"><?php // namespace & uses... class HomeController { public function indexAction() { /* ... */ } public function showArticleAction($slug) { /* ... */ } }</code>
Schritt 3: Zusätzliche Routing -Konfiguration
URL -Standardparameter
festlegen
defaults = { "key" = "value" }
Chemismus:
<code class="language-yaml">blog_front: resource: "@BlogFrontBundle/Controller/" type: annotation prefix: /</code>
slug
Der Platzhalter defaults
wird nicht mehr benötigt, indem der {slug}
-Taste /article
hinzugefügt wird. Die URL slug
stimmt mit dieser Route überein, und der Wert des Parameters hello
wird auf /blog/world
gesetzt. Die URL page
stimmt auch über den Wert des world
-Parameters auf
Anforderungen hinzufügen
requirements = { "key" = "value" }
Chemismus:
<code class="language-php"><?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) { /* ... */ } }</code>
slug
Wir können regelmäßige Ausdrücke verwenden, um die Anforderungen für den Schlüssel {slug}
zu definieren und den Wert von
<code class="language-yaml">blog_front: ... blog_admin: resource: "@BlogAdminBundle/Controller/" type: annotation</code>
Durchsetzen der HTTP -Methode
methods = { "request method" }
Chemismus:
<code class="language-yaml">blog_front_homepage: path : / defaults: { _controller: BlogFrontBundle:Home:index }</code>
Wir können auch mit den Methoden eingehender Anfragen übereinstimmen (z. B. Get, Post, Put, Löschen). Denken Sie daran, dass die Route, wenn keine Methode angegeben ist, jeder Methode übereinstimmt.
http -Lösung
durchsetzen Chemismus: schemes = { "protocol" }
.
<code class="language-php"><?php namespace Blog\FrontBundle\Controller; class HomeController { public function indexAction() { //... 创建并返回一个 Response 对象 } }</code>
In diesem Fall möchten wir sicherstellen, dass die Route über das HTTPS -Protokoll zugegriffen wird.
erzwingen Sie Hostname
Chemismus: host = "myhost.com"
.
<code class="language-yaml">blog_front: resource: "@BlogFrontBundle/Controller/" type: annotation prefix: /</code>
Wir können auch basierend auf HTTP -Hosts übereinstimmen. Dies entspricht nur, wenn der Host myblog.com
ist.
Schritt 4: Übung
Jetzt können wir eine zuverlässige Routing -Struktur erstellen, vorausgesetzt, wir müssen die richtige Route für den Betrieb des Löschens von Artikeln in AdminController.php
erstellen. Wir brauchen:
/admin/delete/article/{id}
definieren;
blog_admin_delete_article
Definieren Sie die Anforderung des id
Endgültige Gedanken
<code class="language-php"><?php namespace Blog\FrontBundle\Controller; use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; class HomeController { /** * @Route("/", name="blog_home_index") */ public function indexAction() { /* ... */ } }</code>
Wie Sie sehen können, ist das Verwalten von Routing mit Anmerkungen einfach zu schreiben, zu lesen und zu warten. Es hat auch den Vorteil, sowohl Code als auch Konfiguration in einer Datei zu konzentrieren: der Controller -Klasse.
Verwenden Sie Anmerkungen oder Standardkonfigurationen? Welches bevorzugen Sie und warum?
Symfony2 Routing Annotation FAQs (FAQs)
(Der FAQs-Teil wird hier weggelassen, da dieser Teil des Inhalts nicht mit dem pseudooriginalen Ziel übereinstimmt und zu lang ist. Bei Bedarf kann eine Pseudo-Orientierungsanforderung für das FAQS-Teil separat gestellt werden.)
Das obige ist der detaillierte Inhalt vonErste Schritte mit Symfony2 Routenanmerkungen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!