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

Erste Schritte mit Symfony2 Routenanmerkungen

William Shakespeare
Freigeben: 2025-02-19 13:24:16
Original
865 Leute haben es durchsucht

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

blog_front_homepage:
  path : /
  defaults:  { _controller: BlogFrontBundle:Home:index }
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
in

: src/Blog/FrontBundle/Controller/HomeController.php

<?php namespace Blog\FrontBundle\Controller;

class HomeController
{
    public function indexAction()
    {
        //... 创建并返回一个 Response 对象
    } 
}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
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

blog_front:
    resource: "@BlogFrontBundle/Controller/"
    type:     annotation
    prefix:   /
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
in

: 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() { /* ... */ }
}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

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

:
blog_front_homepage:
  path : /
  defaults:  { _controller: BlogFrontBundle:Home:index }
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

src/Blog/FrontBundle/Controller/HomeController.php in

:
<?php namespace Blog\FrontBundle\Controller;

class HomeController
{
    public function indexAction()
    {
        //... 创建并返回一个 Response 对象
    } 
}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Verwenden Sie Annotationen

app/config/routing.yml in

:
blog_front:
    resource: "@BlogFrontBundle/Controller/"
    type:     annotation
    prefix:   /
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

src/Blog/FrontBundle/Controller/HomeController.php in

:
<?php 
namespace Blog\FrontBundle\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;

class HomeController
{
    /**
     * @Route("/", name="blog_home_index")
     */
    public function indexAction() { /* ... */ }
}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

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

:
blog_front_homepage:
  path : /
  defaults:  { _controller: BlogFrontBundle:Home:index }

blog_front_article:
  path : /article/{slug}
  defaults:  { _controller: BlogFrontBundle:Home:showArticle }
Nach dem Login kopieren

src/Blog/AdminBundle/Controller/AdminController.php in

:
<?php // namespace & uses...

class HomeController
{
    public function indexAction() { /* ... */ }

    public function showArticleAction($slug) { /* ... */ }
}
Nach dem Login kopieren

Schritt 3: Zusätzliche Routing -Konfiguration

URL -Standardparameter

festlegen defaults = { "key" = "value" } Chemismus:

.
blog_front:
    resource: "@BlogFrontBundle/Controller/"
    type:     annotation
    prefix:   /
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

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:

.
<?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) { /* ... */ }
}
Nach dem Login kopieren

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:
blog_front: ...

blog_admin:
    resource: "@BlogAdminBundle/Controller/"
    type:     annotation
Nach dem Login kopieren

Durchsetzen der HTTP -Methode

methods = { "request method" } Chemismus:

. <🎜>
blog_front_homepage:
  path : /
  defaults:  { _controller: BlogFrontBundle:Home:index }
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

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" }.

<?php namespace Blog\FrontBundle\Controller;

class HomeController
{
    public function indexAction()
    {
        //... 创建并返回一个 Response 对象
    } 
}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

In diesem Fall möchten wir sicherstellen, dass die Route über das HTTPS -Protokoll zugegriffen wird.

erzwingen Sie Hostname

Chemismus: host = "myhost.com".

blog_front:
    resource: "@BlogFrontBundle/Controller/"
    type:     annotation
    prefix:   /
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

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
<?php 
namespace Blog\FrontBundle\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;

class HomeController
{
    /**
     * @Route("/", name="blog_home_index")
     */
    public function indexAction() { /* ... */ }
}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

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!

Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage