Автор Тема: Ошибка 500 после очистки кэша (Dumper.php). Не заходит в админку  (Прочитано 1824 раз)

11 Декабрь 2019, 08:40:08
  • Новичок
  • *
  • Сообщений: 14
  • Репутация: +0/-0
  • Сообщество PrestaShop
    • Просмотр профиля
Всем привет. Почистил кэш, после этого перестало заходить в админку, ошибка 500. На сайт заходит без проблем.

Вот что пишет в файле /public_html/admin/error_log

PHP Fatal error:  Uncaught Symfony\Component\DependencyInjection\Exception\RuntimeException: Cannot dump definition because of invalid class name (NULL) in /home/fpbuz/public_html/vendor/symfony/symfony/src/Symfony/Component/DependencyInjection/Dumper/PhpDumper.php:1403
Stack trace:
#0 /home/fpbuz/public_html/vendor/symfony/symfony/src/Symfony/Component/DependencyInjection/Dumper/PhpDumper.php(790): Symfony\Component\DependencyInjection\Dumper\PhpDumper->dumpLiteralClass('NULL')
#1 /home/fpbuz/public_html/vendor/symfony/symfony/src/Symfony/Component/DependencyInjection/Dumper/PhpDumper.php(394): Symfony\Component\DependencyInjection\Dumper\PhpDumper->addNewInstance('_defaults', Object(Symfony\Component\DependencyInjection\Definition), 'return ', '$this->services...')
#2 /home/fpbuz/public_html/vendor/symfony/symfony/src/Symfony/Component/DependencyInjection/Dumper/PhpDumper.php(639): Symfony\Component\DependencyInjection\Dumper\PhpDumper->addServiceInstance('_defaults', Object(Symfony\Component\DependencyInjection\Definition)) in /home/fpbuz/public_html/vendor/symfony/symfony/src/Symfony/Component/DependencyInjection/Dumper/PhpDumper.php on line 1403

Полное содержимое файла Dumper.php:

<?php

/*
 * This file is part of the Symfony package.
 *
 * (c) Fabien Potencier <fabien@symfony.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Symfony\Component\DependencyInjection\Dumper;

use 
Symfony\Component\DependencyInjection\ContainerBuilder;

/**
 * Dumper is the abstract class for all built-in dumpers.
 *
 * @author Fabien Potencier <fabien@symfony.com>
 */
abstract class Dumper implements DumperInterface
{
    protected 
$container;

    public function 
__construct(ContainerBuilder $container)
    {
        
$this->container $container;
    }
}

Кэш также почистил вручную в папках: /cache/cachefs/    /cache/smarty/ -  не помогло
11 Декабрь 2019, 12:17:30
Ответ #1
  • Ветеран
  • *****
  • Сообщений: 1808
  • Репутация: +49/-1
  • Сообщество PrestaShop
    • Просмотр профиля
Хостеру пишите, проблемы в конф. хостинга. Может php обвновили или весь веб сервер.
11 Декабрь 2019, 12:28:02
Ответ #2
  • Партнер
  • Ветеран
  • ****
  • Сообщений: 22816
  • Репутация: +17143/-1
  • Разработка веб-сайтов и веб-программирование
    • Просмотр профиля
Интернет-магазин под ключ.
Какой выбрать движок для интернет магазина ?
Какой движок лучше ?
Magento или Prestashop ?
Решение всех Ваших вопросов в создании Интернет-магазина.
11 Декабрь 2019, 12:33:32
Ответ #3
  • Новичок
  • *
  • Сообщений: 14
  • Репутация: +0/-0
  • Сообщество PrestaShop
    • Просмотр профиля
Хостеру пишите, проблемы в конф. хостинга. Может php обвновили или весь веб сервер.
Очень вряд ли. Админка стала белой сразу после нажатия "Очистка кэша".
11 Декабрь 2019, 12:34:48
Ответ #4
  • Ветеран
  • *****
  • Сообщений: 22125
  • Репутация: +25303/-1
  • Prestashop - просто и эффективно
    • Просмотр профиля
Такие ошибки обычно после обновления prestashop.
Вы обновляли версию prestashop?
Эксперт Prestashop - решения всех проблем, написание модулей, создание тем для интернет-магазинов под Prestashop.
Эксперт Magento - создам сайт на Magento, программирование кастомных модулей для Magento, кастомизация тем Magento.
Лучшие цены!!!
11 Декабрь 2019, 12:45:11
Ответ #5
  • Новичок
  • *
  • Сообщений: 14
  • Репутация: +0/-0
  • Сообщество PrestaShop
    • Просмотр профиля
Показ ошибок в prestashop включите.
Вот код ошибке в файле /public_html/error_log:
[11-Dec-2019 14:30:50 Asia/Tashkent] PHP Fatal error:  Declaration of AdminApPageBuilderPositionsController::setMedia() must be compatible with AdminControllerCore::setMedia($isNewTheme = false) in /home/fpbuz/public_html/modules/appagebuilder/controllers/admin/AdminApPageBuilderPositions.php on line 23

[11-Dec-2019 14:31:00 Asia/Tashkent] PHP Fatal error:  Allowed memory size of 134217728 bytes exhausted (tried to allocate 8192 bytes) in /home/fpbuz/public_html/classes/db/DbPDO.php on line 187

/public_html/modules/appagebuilder/controllers/admin/AdminApPageBuilderPositions.php:
if (!defined('_PS_VERSION_')) {
    # module validation
    exit;
}

require_once(_PS_MODULE_DIR_.'appagebuilder/classes/ApPageBuilderPositionsModel.php');

23   class AdminApPageBuilderPositionsController extends ModuleAdminControllerCore
{
    public $position_js_folder = '';
    public $position_css_folder = '';
    public $module_name = 'appagebuilder';
    public $explicit_select;
    public $order_by;
    public $order_way;
    public $theme_dir;

/public_html/classes/db/DbPDO.php:

    protected function getAll($result = false)
    {
        if (!$result) {
            $result = $this->result;
        }

        if (!is_object($result)) {
            return false;
        }

      187    return $result->fetchAll(PDO::FETCH_ASSOC);
    }
11 Декабрь 2019, 12:45:54
Ответ #6
  • Новичок
  • *
  • Сообщений: 14
  • Репутация: +0/-0
  • Сообщество PrestaShop
    • Просмотр профиля
Такие ошибки обычно после обновления prestashop.
Вы обновляли версию prestashop?
Нет, просто нажал "Очистка кэша" в админке
11 Декабрь 2019, 12:59:16
Ответ #7
  • Новичок
  • *
  • Сообщений: 14
  • Репутация: +0/-0
  • Сообщество PrestaShop
    • Просмотр профиля
Странно еще вчера была Fatal Error, но с админкой все было в порядке.

[10-Dec-2019 12:40:08 Asia/Tashkent] PHP Fatal error:  Class 'CategoryCore' not found in /home/fpbuz/public_html/classes/PrestaShopAutoload.php(143) : eval()'d code on line 1
PrestaShopAutoload.php:

1 <?php

class PrestaShopAutoload
{
    
/**
     * @var PrestaShopAutoload
     */
    
protected static $instance;

    
/**
     * @var string Root directory
     */
    
protected $root_dir;

    
/**
     *  @var array array('classname' => 'path/to/override', 'classnamecore' => 'path/to/class/core')
     */
    
public $index = array();

    public 
$_include_override_path true;

    protected static 
$class_aliases = array(
        
'Collection' => 'PrestaShopCollection',
        
'Autoload' => 'PrestaShopAutoload',
        
'Backup' => 'PrestaShopBackup',
        
'Logger' => 'PrestaShopLogger'
    
);

    protected function 
__construct()
    {
        
$this->root_dir _PS_CORE_DIR_.'/';
        
$file PrestaShopAutoload::getCacheFileIndex();
        
$stubFile PrestaShopAutoload::getStubFileIndex();
        if (@
filemtime($file) && is_readable($file) && @filemtime($stubFile) && is_readable($stubFile)) {
            
$this->index = include($file);
        } else {
            
$this->generateIndex();
        }
    }

    
/**
     * Get instance of autoload (singleton)
     *
     * @return PrestaShopAutoload
     */
    
public static function getInstance()
    {
        if (!
PrestaShopAutoload::$instance) {
            
PrestaShopAutoload::$instance = new PrestaShopAutoload();
        }

        return 
PrestaShopAutoload::$instance;
    }

    
/**
     * Get Class index cache file
     *
     * @return string
     */
    
public static function getCacheFileIndex()
    {
        return 
_PS_ROOT_DIR_.DIRECTORY_SEPARATOR'app'.DIRECTORY_SEPARATOR.'cache'.DIRECTORY_SEPARATOR.(_PS_MODE_DEV_ 'dev' 'prod').DIRECTORY_SEPARATOR.'class_index.php';
    }

    
/**
     * Get Namespaced class stub file
     *
     * @return string
     */
    
public static function getNamespacedStubFileIndex()
    {
        return 
_PS_ROOT_DIR_.DIRECTORY_SEPARATOR'app'.DIRECTORY_SEPARATOR.'cache'.DIRECTORY_SEPARATOR.(_PS_MODE_DEV_ 'dev' 'prod').DIRECTORY_SEPARATOR.'namespaced_class_stub.php';
    }

    
/**
     * Get Class stub file
     *
     * @return string
     */
    
public static function getStubFileIndex()
    {
        return 
_PS_ROOT_DIR_.DIRECTORY_SEPARATOR'app'.DIRECTORY_SEPARATOR.'cache'.DIRECTORY_SEPARATOR.(_PS_MODE_DEV_ 'dev' 'prod').DIRECTORY_SEPARATOR.'class_stub.php';
    }

    
/**
     * Retrieve informations about a class in classes index and load it
     *
     * @param string $className
     */
    
public function load($className)
    {
        
// Retrocompatibility
        
if (isset(PrestaShopAutoload::$class_aliases[$className]) && !interface_exists($classNamefalse) && !class_exists($classNamefalse)) {
            return eval(
'class '.$className.' extends '.PrestaShopAutoload::$class_aliases[$className].' {}');
        }

        
// regenerate the class index if the requested file doesn't exists
        
if ((isset($this->index[$className]) && $this->index[$className]['path'] && !is_file($this->root_dir.$this->index[$className]['path']))
            || (isset(
$this->index[$className.'Core']) && $this->index[$className.'Core']['path'] && !is_file($this->root_dir.$this->index[$className.'Core']['path']))
            || !
file_exists(self::getNamespacedStubFileIndex())) {
            
$this->generateIndex();
        }

        
// If $classname has not core suffix (E.g. Shop, Product)
        
if (substr($className, -4) != 'Core' && !class_exists($classNamefalse)) {
            
$classDir = (isset($this->index[$className]['override'])
                && 
$this->index[$className]['override'] === true) ? $this->normalizeDirectory(_PS_ROOT_DIR_) : $this->root_dir;

            
// If requested class does not exist, load associated core class
            
if (isset($this->index[$className]) && !$this->index[$className]['path']) {
                require_once(
$classDir.$this->index[$className.'Core']['path']);

                if (
$this->index[$className.'Core']['type'] != 'interface') {
                    eval(
$this->index[$className.'Core']['type'].' '.$className.' extends '.$className.'Core {}');
                }
            } else {
                
// request a non Core Class load the associated Core class if exists
                
if (isset($this->index[$className.'Core'])) {
                    require_once(
$this->root_dir.$this->index[$className.'Core']['path']);
                }

                if (isset(
$this->index[$className])) {
                    require_once(
$classDir.$this->index[$className]['path']);
                }
            }
        } elseif (isset(
$this->index[$className]['path']) && $this->index[$className]['path']) {
            
// Call directly ProductCore, ShopCore class
            
require_once($this->root_dir.$this->index[$className]['path']);
        }
        if (
strpos($className'PrestaShop\PrestaShop\Adapter\Entity') !== false) {
            require_once(
self::getNamespacedStubFileIndex());
        }
    }

    
/**
     * Generate classes index
     */
    
public function generateIndex()
    {
        
$coreClasses $this->getClassesFromDir('classes/');

        
$classes array_merge(
            
$coreClasses,
            
$this->getClassesFromDir('controllers/')
        );

        
$contentNamespacedStub '<?php '."\n".'namespace PrestaShop\\PrestaShop\\Adapter\\Entity;'."\n\n";

        foreach (
$coreClasses as $coreClassName => $coreClass) {
            if (
substr($coreClassName, -4) == 'Core') {
                
$coreClassName substr($coreClassName0, -4);
                if (
$coreClass['type'] != 'interface') {
                    
$contentNamespacedStub .= $coreClass['type'].' '.$coreClassName.' extends \\'.$coreClassName.' {};'."\n";
                }
            }
        }

        if (
$this->_include_override_path) {
            
$coreOverrideClasses $this->getClassesFromDir('override/classes/'defined('_PS_HOST_MODE_'));
            
$coreClassesWOOverrides array_diff_key($coreClasses$coreOverrideClasses);

            
$classes array_merge(
                
$classes,
                
$coreOverrideClasses,
                
$this->getClassesFromDir('override/controllers/'defined('_PS_HOST_MODE_'))
            );
        } else {
            
$coreClassesWOOverrides $coreClasses;
        }

        
$contentStub '<?php'."\n\n";

        foreach (
$coreClassesWOOverrides as $coreClassName => $coreClass) {
            if (
substr($coreClassName, -4) == 'Core') {
                
$coreClassNameNoCore substr($coreClassName0, -4);
                if (
$coreClass['type'] != 'interface') {
                    
$contentStub .= $coreClass['type'].' '.$coreClassNameNoCore.' extends '.$coreClassName.' {};'."\n";
                }
            }
        }

        
ksort($classes);
        
$content '<?php return '.var_export($classestrue).'; ?>
';

        // Write classes index on disc to cache it
        $filename = PrestaShopAutoload::getCacheFileIndex();
        @mkdir(_PS_CACHE_DIR_, 0777, true);

        if (!$this->dumpFile($filename, $content)) {
            Tools::error_log('Cannot write temporary file '.$filename);
        }

        $stubFilename = PrestaShopAutoload::getStubFileIndex();
        if (!$this->dumpFile($stubFilename, $contentStub)) {
            Tools::error_log('Cannot write temporary file '.$stubFilename);
        }

        $namespacedStubFilename = PrestaShopAutoload::getNamespacedStubFileIndex();
        if (!$this->dumpFile($namespacedStubFilename, $contentNamespacedStub)) {
            Tools::error_log('Cannot write temporary file '.$namespacedStubFilename);
        }

        $this->index = $classes;
    }

    /**
     * @param string $filename
     * @param string $content
     *
     * @return bool
     *
     * @see http://api.symfony.com/3.0/Symfony/Component/Filesystem/Filesystem.html#method_dumpFile
     */
    public function dumpFile($filename, $content)
    {
        $dir = dirname($filename);

        // Will create a temp file with 0600 access rights
        // when the filesystem supports chmod.
        $tmpFile = tempnam($dir, basename($filename));
        if (false === @file_put_contents($tmpFile, $content)) {
            return false;
        }
        // Ignore for filesystems that do not support umask
        @chmod($tmpFile, 0666);
        rename($tmpFile, $filename);

        return true;
    }

    /**
     * Retrieve recursively all classes in a directory and its subdirectories
     *
     * @param string $path Relativ path from root to the directory
     *
     * @return array
     */
    protected function getClassesFromDir($path, $hostMode = false)
    {
        $classes = array();
        $rootDir = $hostMode ? $this->normalizeDirectory(_PS_ROOT_DIR_) : $this->root_dir;

        foreach (scandir($rootDir.$path) as $file) {
            if ($file[0] != '.') {
                if (is_dir($rootDir.$path.$file)) {
                    $classes = array_merge($classes, $this->getClassesFromDir($path.$file.'/', $hostMode));
                } elseif (substr($file, -4) == '.php') {
                    $content = file_get_contents($rootDir.$path.$file);

                    $namespacePattern = '[\\a-z0-9_]*[\\]';
                    $pattern = '#\W((abstract\s+)?class|interface)\s+(?P<classname>'.basename($file, '.php').'(?:Core)?)'
                                .'(?:\s+extends\s+'.$namespacePattern.'[a-z][a-z0-9_]*)?(?:\s+implements\s+'.$namespacePattern.'[a-z][\\a-z0-9_]*(?:\s*,\s*'.$namespacePattern.'[a-z][\\a-z0-9_]*)*)?\s*\{#i';

                    //DONT LOAD CLASS WITH NAMESPACE - PSR4 autoloaded from composer
                    $usesNamespace = false;
                    foreach (token_get_all($content) as $token) {
                        if ($token[0] === T_NAMESPACE) {
                            $usesNamespace = true;
                            break;
                        }
                    }

                    if (!$usesNamespace && preg_match($pattern, $content, $m)) {
                        $classes[$m['classname']] = array(
                            'path' => $path.$file,
                            'type' => trim($m[1]),
                            'override' => $hostMode,
                        );

                        if (substr($m['classname'], -4) == 'Core') {
                            $classes[substr($m['classname'], 0, -4)] = array(
                                'path' => '',
                                'type' => $classes[$m['classname']]['type'],
                                'override' => $hostMode,
                            );
                        }
                    }
                }
            }
        }

        return $classes;
    }

    /**
     * Get Class path
     *
     * @param string $classname
     *
     * @return null
     */
    public function getClassPath($classname)
    {
        return (isset($this->index[$classname]) && isset($this->index[$classname]['path'])) ? $this->index[$classname]['path'] : null;
    }

    /**
     * Normalize directory
     *
     * @param string $directory
     *
     * @return string
     */
    private function normalizeDirectory($directory)
    {
        return rtrim($directory, '/\\').DIRECTORY_SEPARATOR;
    }
}

spl_autoload_register(array(PrestaShopAutoload::getInstance(), 'load'));
11 Декабрь 2019, 13:44:45
Ответ #8
  • Партнер
  • Ветеран
  • ****
  • Сообщений: 22816
  • Репутация: +17143/-1
  • Разработка веб-сайтов и веб-программирование
    • Просмотр профиля
Цитировать
Declaration of AdminApPageBuilderPositionsController::setMedia() must be compatible with AdminControllerCore::setMedia($isNewTheme = false
на хостинге устновлено php 7.3, эта версия требует изменний в prestashop, так как не поддерживается на 100%
Интернет-магазин под ключ.
Какой выбрать движок для интернет магазина ?
Какой движок лучше ?
Magento или Prestashop ?
Решение всех Ваших вопросов в создании Интернет-магазина.
11 Декабрь 2019, 13:48:03
Ответ #9
  • Новичок
  • *
  • Сообщений: 14
  • Репутация: +0/-0
  • Сообщество PrestaShop
    • Просмотр профиля
Цитировать
Declaration of AdminApPageBuilderPositionsController::setMedia() must be compatible with AdminControllerCore::setMedia($isNewTheme = false
на хостинге устновлено php 7.3, эта версия требует изменний в prestashop, так как не поддерживается на 100%
В панели хостинга выбрано php 7.0. Если ставлю 7.3, то сайт полностью падает.
11 Декабрь 2019, 13:58:39
Ответ #10
  • Партнер
  • Ветеран
  • ****
  • Сообщений: 22816
  • Репутация: +17143/-1
  • Разработка веб-сайтов и веб-программирование
    • Просмотр профиля
Такие ошибки показывает если установлены:
1. Prestashop <1.7.5 и PHP 7.3
2. Prestashop <1.7 и PHP 7.0
Интернет-магазин под ключ.
Какой выбрать движок для интернет магазина ?
Какой движок лучше ?
Magento или Prestashop ?
Решение всех Ваших вопросов в создании Интернет-магазина.
11 Декабрь 2019, 14:05:38
Ответ #11
  • Новичок
  • *
  • Сообщений: 14
  • Репутация: +0/-0
  • Сообщество PrestaShop
    • Просмотр профиля
Такие ошибки показывает если установлены:
1. Prestashop <1.7.5 и PHP 7.3
2. Prestashop <1.7 и PHP 7.0
Пробовал более ранние версии PHP, там сайт падает. Версия 7.0 всегда была. Раньше же админка работала нормально.
26 Декабрь 2019, 00:11:41
Ответ #12
  • Новичок
  • *
  • Сообщений: 1
  • Репутация: +0/-0
  • Сообщество PrestaShop
    • Просмотр профиля
Нашли ответ? У меня тоже самое произошло! Почистил кэш и белый экран!
26 Декабрь 2019, 01:18:44
Ответ #13
  • Фрилансер
  • *
  • Сообщений: 142
  • Репутация: +0/-0
  • Сообщество PrestaShop
    • Просмотр профиля
Нашли ответ? У меня тоже самое произошло! Почистил кэш и белый экран!
в ручную почистить кеш.
если ошибка таже PhpDumper.php:1403 то попробуй за комментировать  эту строку в этом файле, где-то читал что может помочь.