供应商更新破坏了 FOS 用户包 "Call to a member function has() on a non-object"

Vendor updates broke FOS User Bundle with "Call to a member function has() on a non-object"

我为 Symfony 2.8 项目更新了我的供应商,突然登录页面没有加载 – 相反我得到了这个:

Error: Call to a member function has() on a non-object in vendor/symfony/symfony/src/Symfony/Bundle/FrameworkBundle/Controller/Controller.php at line 184

"name": "hazardlog",
"license": "proprietary",
"type": "project",
"autoload": {
    "psr-4": {
        "": "src/"
    },
    "classmap": [
        "app/AppKernel.php",
        "app/AppCache.php"
    ]
},
"repositories": [
    {
        "type": "package",
        "package": {
            "name": "jquery/jquery",
            "version": "1.11.1",
            "dist": {
                "url": "https://code.jquery.com/jquery-1.11.1.js",
                "type": "file"
            }
        }
    }
],
"require": {
    "php": ">=5.3.9",
    "symfony/symfony": "2.8.*",
    "doctrine/orm": "^2.4.8",
    "doctrine/doctrine-bundle": "~1.4",
    "symfony/swiftmailer-bundle": "~2.3",
    "symfony/monolog-bundle": "~2.4",
    "sensio/distribution-bundle": "~5.0",
    "sensio/framework-extra-bundle": "^3.0.2",
    "incenteev/composer-parameter-handler": "~2.0",
    "braincrafted/bootstrap-bundle": "~2.0",
    "twbs/bootstrap": "3.0.*",
    "jquery/jquery":  "1.11.*",
    "hwi/oauth-bundle": "^0.5.0",
    "friendsofsymfony/user-bundle": "~2.0@dev",
    "stephanecollot/datetimepicker-bundle": "dev-master"
},
"require-dev": {
    "sensio/generator-bundle": "~3.0",
    "symfony/phpunit-bridge": "~2.7"
},
"scripts": {
    "symfony-scripts": [
        "Incenteev\ParameterHandler\ScriptHandler::buildParameters",
        "Sensio\Bundle\DistributionBundle\Composer\ScriptHandler::buildBootstrap",
        "Sensio\Bundle\DistributionBundle\Composer\ScriptHandler::clearCache",
        "Sensio\Bundle\DistributionBundle\Composer\ScriptHandler::installAssets",
        "Sensio\Bundle\DistributionBundle\Composer\ScriptHandler::installRequirementsFile",
        "Sensio\Bundle\DistributionBundle\Composer\ScriptHandler::prepareDeploymentTarget"
    ],
    "post-install-cmd": [
        "@symfony-scripts"
    ],
    "post-update-cmd": [
        "@symfony-scripts"
    ]
},
"config": {
    "bin-dir": "bin"
},
"extra": {
    "symfony-app-dir": "app",
    "symfony-web-dir": "web",
    "symfony-assets-install": "relative",
    "incenteev-parameters": {
        "file": "app/config/parameters.yml"
    }
}

我已经多次看到这种问题,但我找不到一个可以接受的答案和解释。就这样吧。

基本问题在于:

"friendsofsymfony/user-bundle": "~2.0@dev",

当 Symfony 2.8/3.0 首次发布时,稳定的 1.x 版本的 FOSUserBundle 不再有效。 2.x 版本已经开发多年,目前尚无实际路线图确定何时稳定。因此,开发分支被黑客入侵以使其正常工作。人们别无选择,只能使用它,这当然很危险,因为您永远不知道开发更改何时可能会破坏您的代码。

时间过去了,最终稳定的 2.x 版本的 FOSUserBundle 发布了。然而,相当多的开发人员从未抽出时间更新他们的依赖项并继续使用 master 分支。

快进到现在。 Symfony 4 的发布现在已经在 master 分支中引发了大量的开发。对现有 2.8(可能还有 3.0)代码引入重大更改的开发。

底线是使用稳定分支:

"friendsofsymfony/user-bundle": "~2.0",

随后是作曲家更新。

这很奇怪,但今天我做了一个作曲家更新 - composer.json

中的正确配置
"friendsofsymfony/user-bundle": "~2.0",

但一个月前出现同样的错误:

错误:在第 184 行

中的 vendor/symfony/symfony/src/Symfony/Bundle/FrameworkBundle/Controller/Controller.php 中对空值调用成员函数 has()

对于那些使用 Symfony 3.2 的用户,版本“~2.1”似乎与 OP 的版本“~2.0@dev”一起抛出相同的错误。

这有效:

"friendsofsymfony/user-bundle": "2.0"

将它保持在 2.0 对我有用。

我也有同样的问题,但我没有@dev(而且从来没有)

堆栈跟踪有点不同:

in vendor\symfony\symfony\src\Symfony\Bundle\FrameworkBundle\Controller\Controller.php at line 234

这里有这样的问题但是解决了,我只是做了相反的事情。 我有:

"friendsofsymfony/user-bundle": "^2.1",

在我的 composer.json 文件中,它给我一个调用成员函数 has() on null 错误来解决这个问题,我实际上添加了“@dev 它变成了:

"friendsofsymfony/user-bundle": "^2.1@dev",

然后用 :

更新了我的作曲家

composer update