Was ist beim Upgrade von PHP zu beachten?
PHP ist eine Skriptsprache, die hauptsächlich zur Erstellung dynamischer Webseiten oder Webanwendungen verwendet wird. Quasi der Motor der Website. Systemvoraussetzung für gängige Content-Management-Systeme wie WordPress, dessen Themes und Plugins. Für die Version 7.4 werden seit November 2022 keine Sicherheitsupdates mehr bereitgestellt, für ältere wie z. B. der Vorgänger 5.6 ist der Support bereits seit 31. Dezember 2018 eingestellt. Ein Update auf die Version acht oder höher ist daher unbedingt zu empfehlen.
Version | Veröffentlicht | Support | Updates |
7.4 | 28.11.2019 | none | none |
8.0 | 26.11.2020 | none | none |
8.1 | 25.11.2021 | none | 25.11.2024 |
8.2 | 08.12.2022 | 08.12.2024 | 08.12.2025 |
8.3 | 23.11.2023 | 23.11.2025 | 23.11.2026 |
Support erfolgt grundsätzlich ab der ersten stabilen Version für zwei Jahre. Während dieses Zeitraums werden gemeldete Fehler und Sicherheitsprobleme behoben und in regelmäßigen Zwischenversionen veröffentlicht. Für ein weiteres Jahr erfolgen dann Releases für kritische Sicherheitslücken, bevor das End of Life, wie im Fall der Version 8.0, erreicht ist. Countdown für Sicherheitsupdates der Version 8.1:
Während aktuelle Versionen von WordPress, Typo3, Joomla oder Drupal keine Probleme bereiten dürften, sollten aber im Vorfeld unbedingt Themes und Plugins auf Kompatibilität geprüft werde. Die neuen Varianten ab PHP 8.0 bringen größere Veränderungen mit sich. Dass erst 15.1 % der Websites mit WordPress unter PHP v8 und höher laufen (Stand: Januar 2023. Quelle: wordpress.org) sollte niemanden vom auf kurz oder lang zwingenden Umstieg abhalten.
Sie benötigen Unterstützung bei der Migration
Sichern Sie sich Ihr kostenfreies Vorgespräch
Wer sich noch nicht um seine älteren Installationen von WordPress gekümmert hat, sollte dies ebenfalls unbedingt nachholen. Der Support für alle Versionen bis einschließlich 4.0 endete zum 01. Dezember 2022. Aktualisierungen bezüglich der Sicherheit Ihrer Website werden seither nicht mehr bereitgestellt. Dies gilt parallel auch für Typo3 v9 und älter, v10 wird nur bis April 2023 unterstützt.
Versionssprung
Upgrade
Einführung neuer Features wie Fullsize Editing und Darstellung von Bildergalerien als Blöcke, wie beispielsweise in der WordPress Version 5.9 Josephine.
Lückenschluss
Update
Dient der Behebung von Fehlern und der Schließung von Lücken, i.d.R. ändert sich nur die zweite Nachkommastelle, also z.B. WordPress 6.1.1.
Störungsfreiheit
Kompatibilität
WordPress läuft zwar offiziell ab v5.6 mit PHP 8, aus eigener Erfahrung ist ein reibungsloser Betrieb erst ab v5.9 bzw. v6.1 möglich. Typo3 v11 (2020 – 2024) ist mit PHP 8.0 und v12 (2021 – 2026) mit PHP 8.1 sowie 8.2 kompatibel.
Warum PHP aktualisieren?
Die Gründe für ein Update sind vielfältig, doch an erster Stelle stehen vermeidbare Sicherheitsrisiken, die alte, nicht mehr gepflegte Software generell mit sich bringt. Gleichzeit bringt PHP ab den Versionen acht und höher eine Verbesserung der Geschwindigkeit mit. Webseiten werden dank besserer Performance schneller an Besucher:innen ausgegeben. Die Stabilität bleibt gewährleistet, Systemausfälle aufgrund unterschiedlicher Technologien bzw. Standards werden verringert. Die Verfügbarkeit der Homepage besteht, auch wenn der Provider irgendwann nicht umhinkommen wird, alte Versionen abzuschalten. Daher empfiehlt sich u.U. auch eine Kontaktaufnahme mit dem Hostinganbieter. Ggf. wird es zu höheren Kosten für die Nutzung veralteter Software kommen, da höhere Administrations- und Wartungsaufwendungen beispielsweise mittels Sonderleistungen wie einem PHP Extended Support an den Kunden weitergegeben werden.
Wie schwierig ist ein Umstieg auf PHP 8?
Der Aufwand für eine Website unter WordPress v6 mit maximal zehn Plugins (für die Aktualisierungen vorliegen) sollte beispielsweise bei unter einer Stunde liegen. Also bei circa sechs Monatsbeiträgen für einen Extended Support, den Sie dann gar nicht (mehr) brauchen. Je älter eine Website ist und je mehr Plugins eingesetzt werden, desto komplexer wird allerdings die Migration, da potenzielle Fehler und der Aufwand deutlich ansteigen.
Gerne werfe ich einen Blick auf Ihre Website und
berate Sie unverbindlich hinsichtlich der Kosten
Wo liegen die potenziellen Probleme?
Es lassen sich drei Problemfelder einkreisen: erstens das Content-Management-System an sich, zweitens das Theme, Template bzw. Layout sowie drittens die verwendeten Ergänzungen und Plugins. Ganz wesentlich für einen reibungslosen Umstieg ist daher der Umstand, wie alt eine Homepage ist respektive wie gut diese sowie die eingesetzten Plugins gepflegt wurden. Code, der alte Funktionen verwendet, die von neueren Versionen nicht mehr unterstützt werden, sind die Hauptursache allen Übels.
v7.4 | v8.0 | v.8.1 | v8.2 | |
WordPress | 5.6 ff | 6.1 | 6.1 | 6.1 |
Typo3 | 8 bis 10 | 11 | 12 | 12 |
Drupal | 9 | 9 | 9 u. 10 | 9 u. 10 |
Joomla | 3.5 | 3.5 u. 4 | 3.5 u. 4 | 3.5 u. 4 |
Die Unterstützung für PHP 7.0 und 7.1 wird in WordPress 6.6, das im Juli 2024 veröffentlicht werden soll, eingestellt. Die neue unterstützte Mindestversion von PHP wird 7.2.24 sein. Die empfohlene Version von PHP bleibt bei 7.4 oder höher.
A-Z Listing | Zeigt Beiträge, Seiten und Begriffe alphabetisch in einer katalog- oder verzeichnisähnlichen Liste an, allerdings ist die Funktion exclude-posts scheinbar obsolet, sodass ich mir für diese Art von Listen eine eigene Funktion geschrieben habe. |
A.C.F. ab Vers. 6.2.5 | Advanced Cusom Fields bereitet wichtige Änderungen vor, die die Anzeige von Elementen mit the_field auf der Website betreffen. Die Ausgabe von potenziell unsicherem Code wie Skripte und Iframes wird unterbunden. Es wird in solchen Fällen empfohlen, dies mit echo get_field() zu umgehen. Alternativ kann ein Feld auch mit der Funktion add_filter( 'acf/the_field/allow_unsafe_html', function( $allowed, $selector ) freigegeben werden. Mehr Informationen im Blog des Herstellers: www.advancedcustomfields.com. |
Branded Social Images | Teilweise Probleme beim Update, die durch Löschen und neu-initialisieren des Ordner bsi-uploads in wp-content/uploads/ behoben werden konnten. Ggf. Probleme durch imagescale returning false in class.og-image- gd.php . Daher imagejpeg(imagescale($this->resource, $this->manager->width, $this->manager->height, IMG_BICUBIC_FIXED), $this->target, $quality); durch imagejpeg($this->resource, $this->target, $quality); ersetzen. |
Folding Category List | Navigationsleiste die eine Kategorieliste anzeigt, die sich erweitert, wenn man in die einzelnen Unterebenen klicken. Plugin wurde vom Autor eingestellt, unter PHP8 noch begrenzte Funktionalität. |
Multisite Domain Mapping | Vor WordPress 4.5 war für Bereithalten mehrerer Sites und Domains ein Plugin wie WordPress Multisite Domain Mapping erforderlich. Seither ist dies eine native Funktion. Entsprechende Einträge z.B. in der Datei sunrise.php im Ordner wp-content sind damit ebenfalls obsolet. |
Page Scroll to Id | Hier besteht ein Bug in der v1.7.7 (array to string conversation). Ein Fix steht als Developer Version bis zum nächsten Update des Plugin jedoch zum Download zur Verfügung. |
Really Simple Captcha | Dieses muss unter Umständen, je nach Serverkonfiguration, z. B. durch eine Rechenaufgabe ersetzt werden bzw. alternativ durch das Plugin Contact Form 7 Image Captcha. |
Seo Framework | All-In-One-Seo hat mit dem Upgrade der Version 5 einige Änderungen der Struktur erfahren. Je nachdem wo Metas wie Beschreibung eingesetzt werden, muss beispielsweise $meta_description = function_exists( 'the_seo_framework' ) ? the_seo_framework()->get_description( $id ) : ''; in $meta_description = function_exists( 'tsf' ) ? tsf()->data()->plugin()->post()->get_meta_item( '_genesis_description', $id ) : ''; geändert werden. |
Slideshow jQuery Image Gallery | Aus Sicherheitsgründen gesperrt. Mögliche Alternative ist Slider, Gallery, and Carousel by MetaSlider. Bildergalerien müssen allerdings neu aufgesetzt werden. |
Smart 404 | Dieses Plugin wurde nicht mit den letzten Hauptversionen getestet, es bestehen Kompatibilitätsprobleme bei der Verwendung mit neueren Versionen von WordPress. |
WordPress Sort Order | Funktioniert bis PHP v7.4 in meinen Projekten nur in Version 1.2.9. Version 1.3 dagegen klaglos unter v8 und höher. |
Besonderes Augenmerk sollte daher auf Designvorlagen gelegt werden, die vor 2019 programmiert wurden sowie auf die eingesetzten Plugins. Oft wird als Mindestvoraussetzung PHP v5.6 oder höher angegeben, aber das heißt, nicht, dass diese unter PHP v8 auch funktionieren. Parallel sollte überprüft werden, ob die Erweiterungen, für die keine Updates vorliegen, von WordPress nicht wegen Sicherheitsproblemen aus dem Verzeichnis genommen wurden.
Welche Empfehlungen gelten für einen Umstieg?
Grundsätzlich steht bei mir bei jeder größeren Änderung ein Backup der Website sowie der Datenbank an allererster Stelle. Danach sollten WordPress und Plugins aktualisiert und getestet werden, bevor PHP umgestellt und die Homepage erneut von Login im Backend bis hin zur Funktionalität im Frontend geprüft wird. Bei größeren Projekten und umfangreichen Sites empfiehlt sich immer, statt Live eine Installation auf einer lokalen Arbeitsumgebung einzurichten, um alles in Ruhe zu testen und Fehler zu beheben.
Lassen sich Arbeiten zusammenlegen?
Werden Sie proaktiv, statt zu lange zu warten! Neben dem Umstieg sollte auch die Website an sich gleich mit überprüft werden. Templates, Erweiterungen oder alte Installationen, die nicht verwendet werden, sollten der Sicherheit zuliebe entfernt werden. Ebenso werden öfter einmal komplexe Plugins genutzt, die durch wenige Zeilen Code (oft auch dank technischem Fortschritt) eigentlich schon obsolet wären.
Suchmaschinenoptimierung ist in aller Munde. Die beste inhaltliche Optimierung ist für die Katz, wenn es technisch nicht stimmt. Ich liebe daher einen schlanken Code bzw. Quelltext. Überflüssige von WordPress eingespielte Styles (u.a. Classic Theme Styles, Gutenberg Global Styles) können i.d.R. durch Eintrag in der functions.php problemlos entfernt werden. Selbiges gilt z.B. für Emoji’s und sämtliche Prefetches.
Sie planen ein komplettes Redesign? Dann sollte in Betracht gezogen werden, wie die Website ggf. provisorisch umgestellt wird, ohne größere Kosten zu verursachen. Gerne berate ich Sie kostenlos und unverbindlich.