Heim >Backend-Entwicklung >PHP-Tutorial >Der Design Pattern Observer: ein leistungsstarkes Benachrichtigungssystem

Der Design Pattern Observer: ein leistungsstarkes Benachrichtigungssystem

DDD
DDDOriginal
2024-09-13 06:33:11981Durchsuche

Bei der Entwicklung Ihrer Anwendungen ist es häufig erforderlich, dass Ihre Anwendung flexibel auf Ereignisse reagieren kann. Angenommen, Sie möchten mehrere Systeme benachrichtigen, wenn bestimmte Aktionen ausgeführt werden (z. B. Benutzerregistrierung). Hier kommt der Pattern Observer ins Spiel. Mit diesem Muster können Sie eine Beziehung zwischen Objekten herstellen, sodass alle anderen automatisch informiert und aktualisiert werden, wenn sich der Status eines Objekts ändert.

Symfony implementiert dieses Muster dank des Event Dispatcher bereits effektiv, wodurch es sehr praktisch und leistungsstark für die Verwendung in Ihren Projekten ist.

Was ist der Musterbeobachter?

Mit dem Pattern Observer können Sie eine Beziehung zwischen dem beobachteten Subjekt und einem oder mehreren Beobachtern definieren. Wenn am beobachteten Objekt eine Zustandsänderung auftritt, werden alle Beobachter benachrichtigt, damit sie entsprechend reagieren können.

So funktioniert es:

  • ? Subjekt (beobachtbar): Das Hauptobjekt, das seinen Zustand ändert.
  • ? Beobachter: Objekte, die auf Veränderungen im Beobachtbaren reagieren.

Beispiel

Stellen wir uns vor, Sie haben eine Website, auf der sich ein Benutzer registrieren kann. Bei jeder Registrierung möchten Sie eine Willkommens-E-Mail senden, den Benutzer zu einer Newsletter-Liste hinzufügen und ein Analysesystem informieren.

Anstatt alles starr an einem Ort zu programmieren, können Sie diese Aufgaben an verschiedene Beobachter delegieren, die benachrichtigt werden, sobald das Ereignis „Registrierter Benutzer“ ausgelöst wird.

Implementierung des Pattern Observer in Symfony

In Symfony verwenden Sie den Event Dispatcher, um den Pattern Observer einzurichten. Dadurch können Sie den Code übersichtlich organisieren und erweiterbar machen, ohne die Grundlogik zu ändern.

Schritt 1️⃣: Deklarieren Sie das Ereignis

Wir beginnen mit der Erstellung eines Ereignisses, das gesendet wird, wenn sich ein Benutzer registriert. Letzteres enthält die Informationen des Benutzers.

Le Design Pattern Observer : un système de notification puissant

Schritt 2️⃣: Versenden Sie das Ereignis

Jetzt lösen Sie dieses Ereignis in Ihrem Controller oder Dienst aus, wenn sich ein Benutzer registriert.

Le Design Pattern Observer : un système de notification puissant

Schritt 3️⃣: Beobachter (Zuhörer) erstellen

Als nächstes müssen Sie die Beobachter erstellen, die jedes Mal aufgerufen werden, wenn das Registrierungsereignis gesendet wird. Hier sehen Sie das Beispiel, in dem wir eine E-Mail senden und den Benutzer zu einer Newsletter-Liste hinzufügen.

Beobachter 1: Senden Sie eine Willkommens-E-Mail

Le Design Pattern Observer : un système de notification puissant

Beobachter 2: Benutzer zu einer Newsletter-Liste hinzufügen

Le Design Pattern Observer : un système de notification puissant

Schritt 4️⃣: Beobachter konfigurieren

Sie müssen nun die Listener in der Konfiguration registrieren, damit sie auf das user.registered-Ereignis hören.

Fügen Sie in config/services.yaml Beobachter als Dienste hinzu:

Le Design Pattern Observer : un système de notification puissant

ℹ️ Seit Version 5.3 von Symfony können Sie PHP-Attribute verwenden, um Dienste und Ereignis-Listener zu konfigurieren. Dies ist ein modernerer Ansatz, der es Ihnen ermöglicht, Ereignisse direkt in Klassen zu deklarieren, anstatt die Datei „services.yaml“ zu verwenden.
Sie können daher das Attribut #[AsEventListener] direkt in Ihrer Listener-Methode verwenden.

Ich zeige Ihnen, wie Sie die beiden Beobachter mit Attributen anpassen (also ist keine spezielle Konfiguration in config/services.yaml erforderlich? :

Beobachter 1

Le Design Pattern Observer : un système de notification puissant

Beobachter 2

Le Design Pattern Observer : un système de notification puissant

Sedikit penerangan

  • Atribut #[AsEventListener] menunjukkan bahawa kaedah tersebut ialah pendengar untuk acara tertentu.
  • Argumen pertama atribut ialah nama acara yang sedang didengari oleh pemerhati (UserRegisteredEvent::NAME).
  • Dan akhirnya, parameter kaedah menentukan kaedah kelas yang akan dilaksanakan apabila acara dicetuskan (dalam kes kami, onUserRegistered). ?

Langkah 5️⃣: Uji pelaksanaan

Apabila anda mendaftarkan pengguna dengan RegistrationController, acara itu dihantar dan Symfony secara automatik memanggil pemerhati yang sepadan. E-mel dihantar dan pengguna ditambahkan pada senarai surat berita tanpa tindakan/logik ini dicampur dengan kod perniagaan anda.

Mengapa Menggunakan Pemerhati Corak?

Kerana ia adalah penting! Ia akan membolehkan permohonan anda menjadi:

  1. Lebih fleksibel: anda boleh menambah atau mengubah suai pemerhati tanpa menyentuh kod utama anda. Hanya tambahkan pendengar!
  2. Kurang gandingan: bahagian berlainan apl anda tidak berkait rapat. Contohnya, menghantar e-mel dan menambah pada surat berita tidak dikodkan secara langsung dalam pengawal pendaftaran.
  3. Lebih berskala: corak ini memudahkan untuk bertindak balas terhadap peristiwa yang boleh melibatkan beberapa sistem atau perkhidmatan (pemberitahuan, analitis, penghantaran, dll.).

Bonus: Pautan dengan DDD (Reka Bentuk Dipacu Domain)

Pemerhati Corak sering mendapat tempatnya dalam seni bina berdasarkan DDD (Reka Bentuk Dipacu Domain), di mana acara ialah elemen utama (Acara Domain). Peristiwa ini membenarkan bahagian sistem yang berlainan untuk bertindak balas, selalunya di luar domain utama. Tetapi itu perbincangan untuk artikel penuh masa hadapan tentang DDD!

Das obige ist der detaillierte Inhalt vonDer Design Pattern Observer: ein leistungsstarkes Benachrichtigungssystem. 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