Heim >Backend-Entwicklung >PHP-Tutorial >Erste Schritte mit Symfony2 Routenanmerkungen

Erste Schritte mit Symfony2 Routenanmerkungen

William Shakespeare
William ShakespeareOriginal
2025-02-19 13:24:16861Durchsuche

Getting Started with Symfony2 Route Annotations

Kernpunkte

    Mit
  • Symfony2s sensioFrameWorkkextrabundle können Entwickler die Konfiguration direkt im Controller mit Annotationen weiterleiten und eine bequeme Alternative bieten.
  • Routing -Anmerkungen in Symfony2 machen die Routing -Konfiguration modularer, und jede Route ist direkt in seinen entsprechenden Controller -Vorgängen definiert, sodass der Code das Verständnis und die Wartung erleichtert.
  • Annotationen ermöglichen detaillierte Routing -Konfigurationen, einschließlich der Festlegung von URL -Standardparametern, Hinzufügen von Anforderungen, Durchsetzung von HTTP -Methoden oder -Plagen und Durchsetzung von Hostnamen.
  • Während die Verwendung von Anmerkungen Controller -Vorgänge komplizierter machen, da diese jetzt Routing -Konfigurationen enthalten, kann dies durch Einfach und gut dokumentiertes Routing gemindert werden.

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
  • zu beeinflussen
  • type Definieren Sie, wie Routen
  • deklariert werden sollen
  • prefix Präfixe für alle Vorgänge in der Controller -Klasse (optional)
  • definieren

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:

Es sind keine Änderungen erforderlich. Jetzt können Sie auf einen Blick sehen, welcher Betrieb aus dem Routing -Modus aufgerufen wird.

/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

hinzufügen:

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

überein.

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

klar zu definieren, muss nur aus alphabetischen Zeichen bestehen. Im folgenden Beispiel machen wir genau das Gleiche mit der Nummer:
<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:

  • den Pfad als /admin/delete/article/{id} definieren;
  • Definieren Sie den Namen als
  • ; blog_admin_delete_article Definieren Sie die Anforderung des
  • -Tasten nur als numerisch
  • Definiert die Get -Request -Methode. id
  • Die Antwort lautet wie folgt:

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn