Wir haben aufgrund von Serveranpassungen gerade eine PHP-Versions-Umstellung gehabt. Es wurde von PHP-Version 5.6 on 7 umgestellt -ohne Unterstützung der alten Versionen.
Im ersten Augenblick zeigt Magento (Version 1.9.1.1) dann nur noch dies:
Fatal error: Uncaught Error: Function name must be a string in /www/htdocs/app/code/core/Mage/Core/Model/Layout.php:555 Stack trace: #0 /www/htdocs/app/code/core/Mage/Core/Controller/Varien/Action.php(390): Mage_Core_Model_Layout->getOutput() #1 /www/htdocs/app/code/core/Mage/Cms/Helper/Page.php(137): Mage_Core_Controller_Varien_Action->renderLayout() #2 /www/htdocs/app/code/core/Mage/Cms/Helper/Page.php(52): Mage_Cms_Helper_Page->_renderPage(Object(Mage_Cms_IndexController), ‘myone’) #3 /www/htdocs/app/code/core/Mage/Cms/controllers/IndexController.php(45): Mage_Cms_Helper_Page->renderPage(Object(Mage_Cms_IndexController), ‘myone’) #4 /www/htdocs/app/code/core/Mage/Core/Controller/Varien/Action.php(418): Mage_Cms_IndexController->indexAction() #5 /www/htdocs/app/code/co in /www/htdocs/app/code/core/Mage/Core/Model/Layout.php on line 555
Erfreulicherweise kann dies (augenscheinlich) einfach behoben werden. Hierzu wird die Layout.php aus dem Ordner app/code/core/Mage/Core/Model in den Ordner app/code/local/Mage/Core/Model kopiert. Anschließend dann noch die Zeile
$out .= $this->getBlock($callback[0])->$callback[1]();
search (Line 555 wie aus Fehlermeldung zu entnehmen) und durch
$out .= $this->getBlock($callback[0])->{$callback[1]}();
replace.
Anschließend lief das Magento-Frontend wieder problemlos. Weitere Probleme sind frontend-seitig bislang nicht aufgefallen.
Beim Login in das Backend hatten wir noch das Problem, dass die Login-Seite nach Eingabe des Benutzernamens und des Passwortes nur neu geladen wurde. Die eingegebenen Daten waren weg und es gab auch keinen Hinweis auf ein falsches Passwort o.ä.
Hier scheint es sich um ein Problem mit der PHP 7 Version zu handeln, die angeblich bei PHP Version 7 RC3 behoben worden sein soll. Bei uns war es das noch nicht.
Um das Problem zu beheben, haben wir die Datei Session.php aus dem Ordner app/code/core/Mage/Admin/Model in das Verzeichnis app/code/local/Mage/Admin/Model kopiert und (bei uns) in line 120 the line
$this->renewSession();
commented out. Anschließend war auch der Backend-Login problemlos möglich.
Man kann übrigens schon vor der abschließenden Server-Umstellung simulieren wie sich Magento im Falle der Umstellung auf eine andere PHP-Version verhalten würde. Hierzu benötigt man nur Zugriff auf die .htaccess im Basis-Verzeichnis des Magento-Shops.
Standardmäßig ist hier schon (durch das # jeweils auskommentiert)
# Action php5-cgi /cgi-bin/php5-cgi # AddHandler php5-cgi .php
in den ersten Zeilen vermerkt. Mit diesen kann man dann (je nach Hoster) die Version durch CGI-Verwendung umstellen.
Bei uns wäre es z.B. for the 7.0 Simulation
AddHandler php70-cgi .php
been.
Es gibt aber z.B. also
AddHandler application/x-httpd-php7 .php
was mglw. works. Dies ist wie gesagt abhängig vom jeweiligen Hoster und kann durch Anfrage bei diesem oder teilweise auch durch einen Blick ins cPanel o.ä. in Erfahrung gebracht werden.
Used in Magento Version 1.9 Comments? Additions? Notes? Gladly!
Just know on “Inchoo_PHP7” down, which is at least tested.
Thanks for the note - just remember, that on https://github.com/Inchoo/Inchoo_PHP7 is very clearly marked, that the current versions for Magento CE> = 1.9.2.2 have been developed and are also tested for these.
Hallo
thanks for the tip got it done so and my shop is working again
THANK YOU
Yours sincerely,
polleter