我们的项目部分由三个捆绑组成,其中两个包括Web后端应用程序和客户前端单页应用程序使用的相关API,最后一个“CoreBundle”是公共资源所在的位置。
这些bundle都有一个DependencyInjection(DI)bundle子目录,但根本没有Configuration类,因为它们都没有任何特定的配置。我们使用文档中建议的DI组件,理论上该项目中没有可能影响配置加载机制的特殊情况。 这一直运作良好直到现在(Symfony 3.3.2)。
为了将symfony / symfony从3.3.2更新到3.4,编写器安装后脚本Sensio \ Bundle \ DistributionBundle \ Composer \ ScriptHandler :: clearCache生成2个异常:
在Consistency.php第337行:找不到类Bundle \ CoreBundle \ DependencyInjection \ Configuration \ Configuration 在Consistency.php第285行:未找到类Bundle \ CoreBundle \ DependencyInjection \ Configuration \ Configuration
异常跟踪:
Exception trace:
Hoa\Core\Consistency\Consistency::autoload() at n/a:n/a
call_user_func() at /var/www/back-portal/vendor/symfony/symfony/src/Symfony/Component/Debug/DebugClassLoader.php:146
Symfony\Component\Debug\DebugClassLoader->loadClass() at n/a:n/a
spl_autoload_call() at n/a:n/a
class_exists() at /var/www/back-portal/vendor/symfony/symfony/src/Symfony/Component/Config/Resource/ClassExistenceResource.php:78
Symfony\Component\Config\Resource\ClassExistenceResource->isFresh() at /var/www/back-portal/vendor/symfony/symfony/src/Symfony/Component/DependencyInjection/ContainerBuilder.php:351
Symfony\Component\DependencyInjection\ContainerBuilder->getReflectionClass() at /var/www/back-portal/vendor/symfony/symfony/src/Symfony/Component/DependencyInjection/Extension/Extension.php:84
Symfony\Component\DependencyInjection\Extension\Extension->getConfiguration() at /var/www/back-portal/vendor/symfony/symfony/src/Symfony/Component/DependencyInjection/Compiler/MergeExtensionConfigurationPass.php:63
Symfony\Component\DependencyInjection\Compiler\MergeExtensionConfigurationPass->process() at /var/www/back-portal/vendor/symfony/symfony/src/Symfony/Component/HttpKernel/DependencyInjection/MergeExtensionConfigurationPass.php:39
Symfony\Component\HttpKernel\DependencyInjection\MergeExtensionConfigurationPass->process() at /var/www/back-portal/vendor/symfony/symfony/src/Symfony/Component/DependencyInjection/Compiler/Compiler.php:141
Symfony\Component\DependencyInjection\Compiler\Compiler->compile() at /var/www/back-portal/vendor/symfony/symfony/src/Symfony/Component/DependencyInjection/ContainerBuilder.php:760
Symfony\Component\DependencyInjection\ContainerBuilder->compile() at /var/www/back-portal/vendor/symfony/symfony/src/Symfony/Component/HttpKernel/Kernel.php:625
Symfony\Component\HttpKernel\Kernel->initializeContainer() at /var/www/back-portal/vendor/symfony/symfony/src/Symfony/Component/HttpKernel/Kernel.php:137
Symfony\Component\HttpKernel\Kernel->boot() at /var/www/back-portal/vendor/symfony/symfony/src/Symfony/Bundle/FrameworkBundle/Console/Application.php:63
Symfony\Bundle\FrameworkBundle\Console\Application->doRun() at /var/www/back-portal/src/Component/MultiApp/MultiAppConsoleApplication.php:35
Component\MultiApp\MultiAppConsoleApplication->doRun() at /var/www/back-portal/vendor/symfony/symfony/src/Symfony/Component/Console/Application.php:129
Symfony\Component\Console\Application->run() at /var/www/back-portal/bin/console:31
添加一个Configuration类,其getConfigTreeBuilder()
方法返回一个新的(“空”)Treebuilder实例,使异常指出另一个bundle。我为我们的三个捆绑包做了这个,现在异常指出了一个Sensio自己的捆绑包。
在Consistency.php第337行:未找到类Sensio \ Bundle \ DistributionBundle \ DependencyInjection \ Configuration \ Configuration ...
以下是在抛出异常之前产生的一些Composer警告:
Dependency "symfony/polyfill-apcu" is also a root requirement, but is not explicitly whitelisted. Ignoring.
…
Package hoa/core is abandoned, you should avoid using it. Use hoa/consistency instead.
Package guzzle/guzzle is abandoned, you should avoid using it. Use guzzlehttp/guzzle instead.
执行rm -rf var/cache/*
没有帮助。
仅运行bin/console cache:clear
会抛出同样的异常。
既然我们的捆绑实现似乎与这个问题没有任何关系,我甚至不太了解可能是问题的根源。也就是说,行“spl_autoload_call() at n/a:n/a
”看起来很奇怪......可能是某些Symfony依赖应该被迫使用某些版本......? (顺便说一句changelog没有提供有用的暗示潜在原因)
谢谢您的帮助。
TL; DR:这似乎是使用废弃的包hoa/core
的问题。
我可能会在这个问题上找到解决方案,因为我遇到了运行php bin/console
导致错误的同样问题
在Consistency.php第337行:未找到类Sensio \ Bundle \ DistributionBundle \ DependencyInjection \ Configuration \ Configuration ...
在我将Symfony应用程序从2.8升级到最新的3.4版本之后。
我不知道你的确切设置,但我也有关于废弃的hoa/core
包的警告,所以在这里看到你的问题以及我们的设置之间的相似之处,我对此感到好奇,因为它说明了Use hoa/consistency instead.
,而在Consistency.php
类。啊哈!
所以我只是在我的composer.json
上花了很多钱,这是一个过时的条目:
"hoa/regex": "~0.0"
这似乎需要废弃的hoa/core
包。对我来说,只需将其更改为
"hoa/regex": "~1.0"
解决了这个问题。但由于我不知道你的确切composer.json
,我不知道你的捆绑包如何依赖于这个包,所以你可能不那么容易更新到hoa/consistency
。
希望这可以帮助!