Heim >Backend-Entwicklung >PHP-Tutorial >PHP-Entwurfsmuster: Adapter

PHP-Entwurfsmuster: Adapter

Susan Sarandon
Susan SarandonOriginal
2024-10-27 08:59:30485Durchsuche

Das Adapter Design Pattern ist ein Strukturmuster, das die Zusammenarbeit von Objekten mit inkompatiblen Schnittstellen ermöglicht. Es fungiert als Vermittler (oder Adapter) zwischen zwei Objekten und wandelt die Schnittstelle eines Objekts in die vom anderen Objekt erwartete Schnittstelle um. Dadurch können Klassen, die ansonsten inkompatibel wären, weil sie unterschiedliche Schnittstellen haben, ohne Änderungen an ihrem ursprünglichen Code zusammenarbeiten.

Adapterstruktur

Das Adaptermuster besteht im Allgemeinen aus drei Hauptelementen:

  • Client: Die Klasse, die mit Objekten einer bestimmten Schnittstelle arbeiten soll.
  • Adaptee: Die Klasse, die über eine Schnittstelle verfügt, die mit dem Client nicht kompatibel ist, deren Funktionalitäten jedoch erforderlich sind.
  • Adapter: Die Klasse, die die vom Client erwartete Schnittstelle implementiert und Aufrufe in die Adaptee-Schnittstelle umwandelt.

PHP Design Pattern: Adapter

Typen von Adaptern

  1. Objektadapter: Kompositionsbasiert. Der Adapter enthält eine Instanz der Klasse, die er anpasst.
  2. Klassenadapter: Vererbungsbasiert (normalerweise in Sprachen, die Mehrfachvererbung unterstützen).

Wann sollte der Adapter verwendet werden?

  • Wenn Sie eine vorhandene Klasse verwenden möchten, deren Schnittstelle jedoch nicht den Erwartungen des Clients entspricht.
  • Um neue Funktionen in ein Altsystem zu integrieren, ohne den alten Code ändern zu müssen.

Dieses Muster ist nützlich in Systemen, die mit externen Bibliotheken oder APIs arbeiten müssen, sodass Sie deren Funktionalität anpassen können, ohne den Code dieser Bibliotheken zu ändern.

Beispiel mit PHPMailer

Hier ist ein Beispiel für die Verwendung des Adapter-Designmusters zur Integration von PHPMailer in eine benutzerdefinierte Schnittstelle.

Situation:

Nehmen wir an, dass Ihr System erwartet, dass jede E-Mail-Versandklasse eine Schnittstelle namens IMailer implementiert, PHPMailer dieser Schnittstelle jedoch nicht direkt folgt. Der Adapter wird verwendet, um PHPMailer an die vom System erwartete Schnittstelle anzupassen.

PHPMailer über Composer installieren

composer require phpmailer/phpmailer

Verzeichnissystem

?Adapter
 ┣ ?src
 ┃ ┣ ?Interfaces
 ┃ ┃ ┗ ?IMailer.php
 ┃ ┣ ?Adapters
 ┃ ┃ ┗ ?PHPMailerAdapter.php
 ┃ ┗ ?Services
 ┃   ┗ ?ServicoDeEmail.php
 ┣ ?vendor
 ┣ ?composer.json
 ┗ ?index.php

Autoload

Fügen Sie in der Datei „composer.json“ (im Stammverzeichnis des Projekts) den App-Namespace hinzu, um die Klassen automatisch zu laden:

{
    "autoload": {
        "psr-4": {
            "App\": "src/"
        }
    },
    "require": {
        "phpmailer/phpmailer": "^6.5"
    }
}

Schnittstelle IMailer

namespace App\Interfaces;

interface IMailer {
    public function send($to, $subject, $message);
}

Klasse PHPMailerAdapter

namespace App\Adapters;

use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\Exception;
use App\Interfaces\IMailer;

class PHPMailerAdapter implements IMailer {
    private $phpMailer;

    public function __construct() {
        $this->phpMailer = new PHPMailer(true);

        // Basic PHPMailer configuration
        $this->phpMailer->isSMTP();
        $this->phpMailer->Host = 'smtp.example.com';
        $this->phpMailer->SMTPAuth = true;
        $this->phpMailer->Username = 'your-email@example.com';
        $this->phpMailer->Password = 'password';
        $this->phpMailer->SMTPSecure = PHPMailer::ENCRYPTION_STARTTLS;
        $this->phpMailer->Port = 587;
        $this->phpMailer->setFrom('your-email@example.com', 'Your Name');
    }
}
  • Methode senden
public function send($to, $subject, $message) {
    try {
        $this->phpMailer->addAddress($to);
        $this->phpMailer->Subject = $subject;
        $this->phpMailer->Body = $message;
        $this->phpMailer->send();
        echo 'Email sent successfully!';
    } catch (Exception $e) {
        echo "Failed to send email: {$this->phpMailer->ErrorInfo}";
    }
}

Klassen-E-Mail-Service

namespace App\Services;

use App\Interfaces\IMailer;

class EmailService {
    private $mailer;

    public function __construct(IMailer $mailer) {
        $this->mailer = $mailer;
    }
}
  • Methode sendEmailToClient
public function sendEmailToClient($to, $subject, $message) {
    $this->mailer->send($to, $subject, $message);
}

Datei index.php

composer require phpmailer/phpmailer

Erklärung der Struktur

  • IMailer.php: Definiert die IMailer-Schnittstelle, die jedes E-Mail-System implementieren sollte.
  • PHPMailerAdapter.php: Passt PHPMailer an die IMailer-Schnittstelle an.
  • EmailService.php: E-Mail-Dienst, der die IMailer-Schnittstelle zum Versenden von E-Mails verwendet.
  • index.php: Hauptdatei, die den E-Mail-Dienst zum Senden einer Nachricht verwendet.

Das obige ist der detaillierte Inhalt vonPHP-Entwurfsmuster: Adapter. 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