


Behebung von PHP_CodeSniffer Null Trim()-Fehlern in WordPress-Codierungsstandards
Oct 16, 2024 am 06:11 AMBeim Arbeiten an WordPress-Projekten mit PHP 8.x kann die folgende Fehlermeldung auftreten:
Schwerwiegender Fehler: Uncaught PHP_CodeSnifferExceptionsRuntimeException: trim(): Die übergabe von Null an Parameter Nr. 1 ($string) vom Typ string ist in /path/... veraltet.
Dieser Fehler tritt aufgrund einer veralteten Warnung in PHP 8.x auf, bei der die übergabe von Null an die Funktion trim() nicht mehr zul?ssig ist. Dieses Problem tritt insbesondere im Rahmen eines WordPress Coding Standards (WPCS)-Sniffs auf, der Teil des PHP_CodeSniffer-Setups ist. Zum Zeitpunkt der Erstellung dieses Artikels besteht dieses Problem weiterhin, selbst mit den neuesten Versionen von PHP_CodeSniffer und WordPress Coding Standards.
PHP_CodeSniffer und WPCS verstehen
PHP_CodeSniffer ist ein Tool, das Entwicklern hilft, Codierungsstandards einzuhalten, indem es ihren PHP-Code auf Verst??e gegen bestimmte Regeln überprüft. WordPress Coding Standards (WPCS) bieten eine Reihe von Richtlinien zum Schreiben von konsistentem und sauberem Code in WordPress-Projekten. Der oben erw?hnte Fehler weist typischerweise darauf hin, dass ein Codeausschnitt diese Standards aufgrund von ?nderungen im Verhalten von PHP nicht einh?lt.
Festsetzung
Um dies zu beheben, k?nnen wir die Datei, die das Problem verursacht, manuell ?ndern, die Zeile suchen, in der trim() aufgerufen wird, und den Code aktualisieren, um sicherzustellen, dass Nullwerte beim Aufruf von trim() ordnungsgem?? behandelt werden.
Suchen Sie beispielsweise in der Datei vendor/wp-coding-standards/wpcs/WordPress/Sniffs/NamingConventions/PrefixAllGlobalsSniff.php die Zeile 280 und ersetzen Sie die folgende Zeile:
// this $cl_prefixes = trim( PHPCSHelper::get_config_data( 'prefixes' ); // to this $cl_prefixes = is_null( PHPCSHelper::get_config_data( 'prefixes' ) ) ? '' : trim( PHPCSHelper::get_config_data( 'prefixes' ) );
Aber wie bei vielen Entscheidungen in der Softwareentwicklung nur weil Sie dies tun k?nnen, hei?t das nicht, dass Sie es tun sollten.
W?hrend der vorherige Ansatz den Fehler beheben kann, ist es wichtig, sich daran zu erinnern, dass das ?ndern von Herstellerdateien keine nachhaltige L?sung ist. ?nderungen gehen jedes Mal verloren, wenn Sie Ihre Abh?ngigkeiten über Composer aktualisieren.
Ein besserer Ansatz besteht darin, eine Patch-Datei zu erstellen.
Erstellen einer Patch-Datei
Hier finden Sie eine Schritt-für-Schritt-Anleitung zum Erstellen und Anwenden eines Patches für das Problem
Erstellen Sie die Patch-Datei
Eine robustere L?sung besteht darin, eine Patch-Datei zu erstellen. Mit dieser Methode k?nnen Sie Ihre ?nderungen jedes Mal automatisch anwenden, wenn Sie Ihre Abh?ngigkeiten installieren oder aktualisieren.
Eine Patchdatei ist eine Textdatei, die die Unterschiede zwischen zwei Versionen einer Datei enth?lt – im Wesentlichen ein ?Vorher“- und ?Nachher“-Schnappschuss.
Erstellen Sie in Ihrem Projektverzeichnis einen Ordner für die Patchdatei:
mkdir -p Patches
Erstellen Sie im Ordner ?patches/“ eine neue Patchdatei mit dem Namen ?fix-null-trim.patch“. Sie k?nnen dies mit Ihrem Texteditor tun:
Touch patches/fix-null-trim.patch
?ffnen Sie fix-null-trim.patch in Ihrem Texteditor und fügen Sie den folgenden Inhalt hinzu:
--- a/vendor/wp-coding-standards/wpcs/WordPress/Sniffs/NamingConventions/PrefixAllGlobalsSniff.php +++ b/vendor/wp-coding-standards/wpcs/WordPress/Sniffs/NamingConventions/PrefixAllGlobalsSniff.php @@ -280,7 +280,7 @@ // Original code with `trim()` // Update this line: - $cl_prefixes = trim( PHPCSHelper::get_config_data( 'prefixes' ) ); + $cl_prefixes = is_null( PHPCSHelper::get_config_data( 'prefixes' ) ) ? '' : trim( PHPCSHelper::get_config_data( 'prefixes' ) ); --- a/vendor/wp-coding-standards/wpcs/WordPress/Sniffs/WP/I18nSniff.php +++ b/vendor/wp-coding-standards/wpcs/WordPress/Sniffs/WP/I18nSniff.php @@ -194,7 +194,7 @@ // Original code with `trim()` // Update this line: - $cl_text_domain = trim( PHPCSHelper::get_config_data( 'text_domain' ) ); + $cl_text_domain = is_null(PHPCSHelper::get_config_data( 'text_domain' )) ? '' : trim( PHPCSHelper::get_config_data( 'text_domain' ) ); --- a/vendor/wp-coding-standards/wpcs/WordPress/Sniffs/Sniff.php +++ b/vendor/wp-coding-standards/wpcs/WordPress/Sniffs/Sniff.php @@ -1144,7 +1144,7 @@ // Original code with `trim()` // Update this line: - $cl_supported_version = trim( PHPCSHelper::get_config_data( 'minimum_supported_wp_version' ) ); + $cl_supported_version = is_null(PHPCSHelper::get_config_data( 'minimum_supported_wp_version' )) ? '' : trim( PHPCSHelper::get_config_data( 'minimum_supported_wp_version' ) );
Dieser Patch weist Composer an, die problematische Zeile in PrefixAllGlobalsSniff.php durch eine sicherere Version zu ersetzen, die den Null-Koaleszenzoperator (??) verwendet, um die übergabe von Null an trim() zu vermeiden.
?ndern Sie ?composer.json“, um den Patch anzuwenden
Als n?chstes müssen Sie Composer anweisen, diesen Patch automatisch anzuwenden, wenn Sie Ihre Abh?ngigkeiten installieren oder aktualisieren.
?ffnen Sie die Datei ?composer.json“ Ihres Projekts. Fügen Sie im Abschnitt ?Extra“ die folgende Konfiguration hinzu. Wenn der Abschnitt ?Extra“ noch nicht vorhanden ist, müssen Sie ihn erstellen.
json "extra": { "patches": { "wp-coding-standards/wpcs": { "Fix null trim() issue": "patches/fix-null-trim.patch" } } }
Dadurch wird Composer angewiesen, die Datei ?fix-null-trim.patch“ auf das Paket ?wp-coding-standards/wpcs“ anzuwenden, wenn Abh?ngigkeiten installiert oder aktualisiert werden.
Installieren Sie das Composer-Patch-Plugin
Um Patches über Composer anzuwenden, ben?tigen Sie das Composer-Patches-Plugin. Führen Sie zur Installation den folgenden Befehl aus:
Komponisten ben?tigen Cweagans/Composer-Patches
Wenden Sie den Patch an
Jetzt k?nnen Sie den Patch anwenden, indem Sie den folgenden Befehl ausführen:
Composer-Installation
W?hrend der Installation wendet Composer den Patch aus dem Ordner ?patches/“ auf die Datei ?PrefixAllGlobalsSniff.php“ an.
Durch das Erstellen und Anwenden einer Patchdatei stellen Sie sicher, dass Ihre Korrekturen über alle Composer-Updates hinweg bestehen bleiben und befolgen dabei die Best Practices in der Softwareentwicklung. überwachen Sie regelm??ig Aktualisierungen von PHP_CodeSniffer und WordPress Coding Standards, da diese Probleme m?glicherweise in zukünftigen Versionen behoben werden. Dieser proaktive Ansatz verbessert nicht nur die Codequalit?t, sondern verbessert auch Ihren Entwicklungsworkflow in PHP 8.x-Umgebungen.
Ich habe die Patch-Datei in diesem Gist geteilt. Sie k?nnen es gerne als Referenz verwenden, um ?hnliche Korrekturen in Ihren Projekten zu implementieren!
Das obige ist der detaillierte Inhalt vonBehebung von PHP_CodeSniffer Null Trim()-Fehlern in WordPress-Codierungsstandards. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

Hei?er Artikel

Hei?e Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Hei?e Themen

TosecurelyHandleAuthenticationAuthorizationInphp, folge theSteps: 1.Alwayshashpasswordswithpassword_hash () und password_verify (), usePreeParedStatementStopreventsQlinjapitca und StoreuserDatain $ _SessionArtelogin.2.ImplementscaChescescesc

Um Datei -Uploads in PHP sicher zu verarbeiten, besteht der Kern darin, Dateitypen zu überprüfen, Dateien umzubenennen und die Berechtigungen zu beschr?nken. 1. Verwenden Sie Finfo_File (), um den realen MIME -Typ zu überprüfen, und nur bestimmte Typen wie Bild/JPEG sind zul?ssig. 2. Verwenden Sie Uniqid (), um zuf?llige Dateinamen zu generieren und sie im Root-Verzeichnis ohne Web zu speichern. 3.. Begrenzen Sie die Dateigr??e durch Php.ini- und HTML -Formulare und setzen Sie die Verzeichnisberechtigungen auf 0755; 4. Verwenden Sie Clamav, um Malware zu scannen, um die Sicherheit zu verbessern. Diese Schritte verhindern effektiv Sicherheitslücken und stellen sicher, dass der Upload -Prozess des Datei -Uploads sicher und zuverl?ssig ist.

In PHP ist der Hauptunterschied zwischen == und == die Strenge der Typprüfung. == Die Konvertierung des Typs wird vor dem Vergleich durchgeführt, beispielsweise 5 == "5" gibt true zurück und === fordert an, dass der Wert und der Typ gleich sind, bevor True zurückgegeben wird, z. B. 5 === "5" gibt false zurück. In den Nutzungsszenarien ist === sicherer und sollte zuerst verwendet werden, und == wird nur verwendet, wenn die Typumwandlung erforderlich ist.

Die Methoden zur Verwendung grundlegender mathematischer Operationen in PHP sind wie folgt: 1. Additionszeichen unterstützen Ganzfaktoren und Floating-Punkt-Zahlen und k?nnen auch für Variablen verwendet werden. String -Nummern werden automatisch konvertiert, aber nicht für Abh?ngigkeiten empfohlen. 2. Subtraktionszeichen verwenden - Zeichen, Variablen sind gleich, und die Typumwandlung ist ebenfalls anwendbar. 3. Multiplikationszeichen verwenden * Zeichen, die für Zahlen und ?hnliche Zeichenfolgen geeignet sind; 4. Division verwendet / Zeichen, die vermeiden müssen, durch Null zu dividieren, und beachten Sie, dass das Ergebnis m?glicherweise schwimmende Punktzahlen sein kann. 5. Die Modulzeichen k?nnen verwendet werden, um ungerade und sogar Zahlen zu beurteilen, und wenn negative Zahlen verarbeitet werden, stimmen die Restzeichen mit der Dividende überein. Der Schlüssel zur korrekten Verwendung dieser Operatoren liegt darin, sicherzustellen, dass die Datentypen klar sind und die Grenzsituation gut behandelt wird.

Ja, PHP kann mit NoSQL -Datenbanken wie MongoDB und Redis durch bestimmte Erweiterungen oder Bibliotheken interagieren. Verwenden Sie zun?chst den MongoDBPHP -Treiber (installiert über PECL oder Composer), um Client -Instanzen zu erstellen und Datenbanken und Sammlungen zu betreiben, wobei Sie Insertion, Abfrage, Aggregation und andere Vorg?nge unterstützen. Zweitens verwenden Sie die Predis Library oder PHPREDIS-Erweiterung, um eine Verbindung zu Redis herzustellen, Schlüsselwerteinstellungen und -akquisitionen durchzuführen und PHPREDIS für Hochleistungsszenarien zu empfehlen, w?hrend Predis für die schnelle Bereitstellung bequem ist. Beide sind für Produktionsumgebungen geeignet und gut dokumentiert.

TostaycurrentwithPHPdevelopmentsandbestpractices,followkeynewssourceslikePHP.netandPHPWeekly,engagewithcommunitiesonforumsandconferences,keeptoolingupdatedandgraduallyadoptnewfeatures,andreadorcontributetoopensourceprojects.First,followreliablesource

PHPBECAMEPOPULARFORWebDevelopmentDuetoitSeaseoflearning, Seamlessintegrationwithhtml, weit verbreitete Hostingsupport, andalargeecosystemincludingFrameWorkelaravelandcmsplatformen -?hnliche WordPress.itexcelsinformlingsformen, Managingusesersions, Interacti

Tosettherighttimezoneinphp, usedate_default_timezone_set () functionAtthestartofyourScriptWithAvalididentifiersuchas'america/new_york'.1.usedate_default_timezone_set () beeanydate/timeFununtions.2.Alternativ, konfigurieren
