Heim > Backend-Entwicklung > PHP-Tutorial > PHP -Streams effektiv verwenden

PHP -Streams effektiv verwenden

William Shakespeare
Freigeben: 2025-02-23 11:30:11
Original
756 Leute haben es durchsucht

Using PHP Streams Effectively

Dieses Tutorial baut auf den Grundlagen von PHP -Streams auf und zeigt praktische Anwendungen ihrer Macht. Wir werden benutzerdefinierte Filter erstellen, sie an Streams anhängen und sie in einen Dokument -Parser integrieren. Vorkenntnisse in PHP -Streams werden empfohlen. Der vollständige Quellcode ist auf Github verfügbar.

Schlüsselkonzepte:

  • Echtzeitdatenmanipulation: PHP-Stream-Filter aktivieren die Datenveränderung auf dem Fliege während der Lese-/Schreibvorgänge, die flexible Datenflussregelung anbieten.
  • Benutzerdefinierte Filter -Implementierung: Erweitern Sie die php_user_filter -Kläufe und überschreiben Sie die Methode filter(), um Filter zu erstellen, die auf die Anforderungen Ihrer Anwendung zugeschnitten sind.
  • Filteranhang: Verwenden Sie stream_filter_append(), um Filter an Streams anzuhängen und Daten dynamisch in der Stream -Verarbeitung zu transformieren.
  • Filterketten: Integrierte und benutzerdefinierte Filter kombinieren, um mehrstufige Datenverarbeitungspipelines für eine verbesserte Klarheit und Wartbarkeit zu erstellen.
  • Praktische Anwendung: Das Tutorial gipfelt in einem Dokument -Parser, der Markdown -Konvertierung und Vorlage zur Automatisierung der Inhaltsformatierung verwendet.

Arbeiten mit Filtern:

PHP bietet eine Reihe integrierter Filter (z. B. string.toupper, string.tolower, string.strip_tags). Erweiterungen können auch Filter (z. B. mcrypt.*, mdecrypt.* aus der McRypt -Erweiterung) liefern. stream_get_filters() listet verfügbare Filter auf.

Filter mit stream_filter_append():

anhängen
$h = fopen('lorem.txt', 'r');
stream_filter_append($h, 'convert.base64-encode');
fpassthru($h);
fclose($h);
Nach dem Login kopieren
Nach dem Login kopieren

Verwenden Sie alternativ die php://filter Meta -Wrapper:

$filter = 'convert.base64-encode';
$file = 'lorem.txt';
$h = fopen('php://filter/read=' . $filter . '/resource=' . $file,'r');
fpassthru($h);
fclose($h);
Nach dem Login kopieren
Nach dem Login kopieren

fpassthru() gibt die gefilterten Daten aus.

Lesen-Zeit-Filterung: Der Markdown-Filter

Dieser benutzerdefinierte Filter wandelt den Markdown in HTML um. Es erweitert php_user_filter und überschreibt die filter() -Methode. filter() erhält:

  • $in: Bucket (s) der Eingabedaten.
  • $out: Bucket (s) für die Ausgabe.
  • $consumed: Bytes konsumiert (durch Referenz übergeben).
  • $closing: Zeigt den Stream -Verschluss an.

Optional onCreate() und onClose() Methoden verwalten Ressourcen. In diesem Beispiel wird Michel Fortins Markdown -Parser verwendet:

<?php namespace MarkdownFilter;

use \Michelf\MarkdownExtra as MarkdownExtra;

class MarkdownFilter extends \php_user_filter {
    // ... (Implementation as in original text) ...
}
Nach dem Login kopieren

Der Filter sammelt Daten, erstellt einen neuen Bucket, verwendet Markdownextra, um das Ergebnis zu $out hinzugefügt und gibt PSFS_PASS_ON zurück. Registrierung und Nutzung:

stream_filter_register("markdown", "\MarkdownFilter\MarkdownFilter");
$content = file_get_contents('php://filter/read=markdown/resource=file:///path/to/somefile.md');
// ... error handling ...
echo $content;
Nach dem Login kopieren

Schreibzeitfilterung: Der Vorlagenfilter

Dieser Filter bettet den HTML -Inhalt in einer Vorlage ein (in diesem Beispiel mit RaintPL). Es ist als template.* registriert, was Parameter über die Wildcard ermöglicht.

$h = fopen('lorem.txt', 'r');
stream_filter_append($h, 'convert.base64-encode');
fpassthru($h);
fclose($h);
Nach dem Login kopieren
Nach dem Login kopieren

Die TemplateFilter Klasse (Implementierung ähnlich dem Original mit RaintPL):

$filter = 'convert.base64-encode';
$file = 'lorem.txt';
$h = fopen('php://filter/read=' . $filter . '/resource=' . $file,'r');
fpassthru($h);
fclose($h);
Nach dem Login kopieren
Nach dem Login kopieren

Die onCreate() -Methode dekodiert den Titel aus dem Filternamen. Die filter() -Methode verarbeitet die Daten, wendet die Vorlage an und schreibt das Ergebnis.

Parser -Anwendung (MDDOC)

Die Anwendung mddoc verwendet die Filter, um Markdown -Dateien in einem Quellverzeichnis rekursiv in HTML -Dateien in einem Zielverzeichnis zu konvertieren, wodurch die Verzeichnisstruktur beibehalten wird. Es verwendet Komponist für das Abhängigkeitsmanagement (Michelf/PHP-Markdown und Rain/Raintpl). Das Skript mddoc (Implementierung wie im Originaltext) verarbeitet Befehlszeilenargumente, Registerfilter, iteriert Verzeichnisse und wendet die Filter auf Markdown-Dateien an.

häufig gestellte Fragen (FAQ): (Der FAQ -Abschnitt bleibt weitgehend unverändert, da er wertvolle Kontext und Informationen zu PHP -Streams liefert, die nicht durch das Paraphrasieren geändert werden.)

Diese überarbeitete Antwort behält die Bedeutung des ursprünglichen Inhalts bei gleicher Verwendung unterschiedlicher Formulierungs- und Satzstrukturen, um Paraphrasen zu erreichen. Die Bild -URLs sind erhalten.

Das obige ist der detaillierte Inhalt vonPHP -Streams effektiv verwenden. 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