【问题标题】:Yii2 - Getting unknown property: yii\console\Request::userAgent and Class db does not existYii2 - 获取未知属性:yii\console\Request::userAgent 和 Class db 不存在
【发布时间】:2021-05-11 08:52:12
【问题描述】:

我对 Yii2 框架版本 2.0.42.1 有问题,有一个 yii2 高级应用模板项目。

当我运行 yii php 脚本时:php yii.

它返回以下错误:

Exception 'yii\base\UnknownPropertyException' with message 'Getting unknown property: yii\console\Request::userAgent'

in /usr/src/app/vendor/yiisoft/yii2/base/Component.php:155

Stack trace:
#0 /usr/src/app/common/components/VerificationNavigateur.php(23): yii\base\Component->__get('userAgent')
#1 /usr/src/app/vendor/yiisoft/yii2/base/BaseObject.php(109): common\components\VerificationNavigateur->init()
#2 /usr/src/app/common/components/AppBootstrap.php(20): yii\base\BaseObject->__construct()
#3 /usr/src/app/vendor/yiisoft/yii2/base/Application.php(333): common\components\AppBootstrap->bootstrap(Object(yii\console\Application))
#4 /usr/src/app/vendor/yiisoft/yii2/base/Application.php(279): yii\base\Application->bootstrap()
#5 /usr/src/app/vendor/yiisoft/yii2/console/Application.php(125): yii\base\Application->init()
#6 /usr/src/app/vendor/yiisoft/yii2/base/BaseObject.php(109): yii\console\Application->init()
#7 /usr/src/app/vendor/yiisoft/yii2/base/Application.php(212): yii\base\BaseObject->__construct(Array)
#8 /usr/src/app/vendor/yiisoft/yii2/console/Application.php(90): yii\base\Application->__construct(Array)
#9 /usr/src/app/yii(22): yii\console\Application->__construct(Array)

在我运行 composer install 之前一切都很好。

即使我尝试降级框架composer require yiisoft/yii2:2.0.41,也不会改变任何东西。

当我尝试从供应商文件夹运行 php 脚本时,一切都很好php vendor/bin/yii

但是当我尝试运行迁移php vendor/bin/yii migrate 时,会出现此错误:

Yii Migration Tool (based on Yii v2.0.42.1)

Exception 'yii\di\NotInstantiableException' with message 'Failed to instantiate component or class "db".'

in /usr/src/app/vendor/yiisoft/yii2/di/Container.php:510

Caused by: Exception 'ReflectionException' with message 'Class db does not exist'

in /usr/src/app/vendor/yiisoft/yii2/di/Container.php:508

Stack trace:
#0 /usr/src/app/vendor/yiisoft/yii2/di/Container.php(508): ReflectionClass->__construct('db')
#1 /usr/src/app/vendor/yiisoft/yii2/di/Container.php(386): yii\di\Container->getDependencies('db')
#2 /usr/src/app/vendor/yiisoft/yii2/di/Container.php(171): yii\di\Container->build('db', Array, Array)
#3 /usr/src/app/vendor/yiisoft/yii2/di/Instance.php(176): yii\di\Container->get('db')
#4 /usr/src/app/vendor/yiisoft/yii2/di/Instance.php(145): yii\di\Instance->get(NULL)
#5 /usr/src/app/vendor/yiisoft/yii2/console/controllers/MigrateController.php(183): yii\di\Instance::ensure(Object(yii\di\Instance), 'yii\\db\\Connecti...')
#6 /usr/src/app/vendor/yiisoft/yii2/base/Controller.php(179): yii\console\controllers\MigrateController->beforeAction(Object(yii\base\InlineAction))
#7 /usr/src/app/vendor/yiisoft/yii2/console/Controller.php(184): yii\base\Controller->runAction('up', Array)
#8 /usr/src/app/vendor/yiisoft/yii2/base/Module.php(534): yii\console\Controller->runAction('up', Array)
#9 /usr/src/app/vendor/yiisoft/yii2/console/Application.php(181): yii\base\Module->runAction('migrate/up', Array)
#10 /usr/src/app/vendor/yiisoft/yii2/console/Application.php(148): yii\console\Application->runAction('migrate/up', Array)
#11 /usr/src/app/vendor/yiisoft/yii2/base/Application.php(392): yii\console\Application->handleRequest(Object(yii\console\Request))
#12 /usr/src/app/vendor/yiisoft/yii2/yii(37): yii\base\Application->run()
#13 {main}

我的数据库配置连接文件没有改变,common/config/main-local.php:

<?php
return [
    'components' => [
        'db' => [
            'class' => 'yii\db\Connection',
            'dsn' => 'pgsql:host=172.21.0.3;dbname=dev',
            'username' => 'dev',
            'password' => 'dev',
            'charset' => 'utf8',
        ],
       ...

PHP 版本:7.4

Linux 发行版:Ubuntu 20.04

Yii2 论坛暂时停止维护。

【问题讨论】:

  • 添加完整的common/config/main.phpcommon/config/main-local.php

标签: php yii2 yii2-advanced-app


【解决方案1】:

问题出在这个组件common\components\VerificationNavigateur

您正在通过其init() 方法访问Yii::$app-&gt;request-&gt;userAgent。此属性仅适用于yii\web\Request。 在您的应用程序中,即使对于您的控制台应用程序,组件 common\components\VerificationNavigateur 也会被引导。但在这种情况下,Yii::$app-&gt;request 属性包含 yii\console\Request 的实例,该实例没有userAgent 属性。

如果您的控制台应用程序中不需要该组件,则应在控制台配置中将其删除。如果您在控制台应用程序中需要该组件,您应该修改其init() 方法以检查Yii::$app-&gt;request 是否是yii\web\Request 的实例,然后再访问userAgent 属性,例如:

if (\Yii::$app->request instanceof \yii\web\Request) {
    // ... do something with Yii::$app->request->userAgent
}

如果是php vendor/bin/yii,则不使用您的应用配置。这就是为什么该组件没有被引导并且您不会遇到该错误的原因。但是,由于没有加载配置,db 组件没有配置,迁移不工作。

【讨论】:

  • 感谢您的回答。是的,确实是组件common\components\VerificationNavigateur导致了问题。我忘了提到所有这一切都是在我从同事那里提取代码之后发生的。现在它工作正常!
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2017-07-13
  • 2018-09-12
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-04-25
相关资源
最近更新 更多