【问题标题】:Laravel class not being compiled on first runLaravel 类在第一次运行时没有被编译
【发布时间】:2015-06-29 20:52:28
【问题描述】:

我使用了发布在 Net Tuts+ (http://hub.tutsplus.com/tutorials/combining-laravel-4-and-backbone--net-31745) 上的教程,并按照说明实现了错误处理。

在 composer 自动加载部分,我加载了 error.php 文件。它包含一个名为 NotFoundException 的类,用于为 REST 请求创建异常。

当我使用 artisan 转储自动加载时,它构建得很好,并且在第一次运行时,我收到错误“ReflectionException:Class NotFoundException 不存在”。这仅在转储后的第一次运行时发生。后续运行很好,当我遇到触发异常的实例时,异常类起作用。每次我运行单元测试时都会出现这个错误,导致我的测试失败,但它只出现在调用异常的第一个文件中。我在 2 个单独的文件中有 2 个测试,它们运行并且都使用异常作为断言,第一个得到错误,而第二个通过。

我对 Laravel 还是很陌生,所以这可能是一个简单的修复,但我错过了什么吗?我应该忽略另一个参考吗?

以下步骤的输出:

root@ubuntu:/var/www/api# composer dump-autoload
Generating autoload files
root@ubuntu:/var/www/api# php artisan clear-compiled
root@ubuntu:/var/www/api# php artisan optimize
Generating optimized class loader
Compiling common classes
root@ubuntu:/var/www/api# phpunit
PHPUnit 3.7.22 by Sebastian Bergmann.

Configuration read from /var/www/api/phpunit.xml

E........................................

Time: 2 seconds, Memory: 46.00Mb

There was 1 error:

1) AuthControllerTest::testProcess
ReflectionException: Class NotFoundException does not exist

/var/www/api/bootstrap/compiled.php:7539
/var/www/api/bootstrap/compiled.php:7533
/var/www/api/bootstrap/compiled.php:7508
/var/www/api/bootstrap/compiled.php:7477
/var/www/api/bootstrap/compiled.php:7472
/var/www/api/vendor/composer/ClassLoader.php:185
/var/www/api/vendor/composer/ClassLoader.php:185
/var/www/api/bootstrap/compiled.php:165
/var/www/api/bootstrap/compiled.php:142
/var/www/api/bootstrap/compiled.php:444
/var/www/api/bootstrap/compiled.php:83
/var/www/api/bootstrap/compiled.php:163
/var/www/api/bootstrap/compiled.php:142
/var/www/api/bootstrap/compiled.php:444
/var/www/api/bootstrap/compiled.php:186
/var/www/api/bootstrap/compiled.php:175
/var/www/api/bootstrap/compiled.php:142
/var/www/api/bootstrap/compiled.php:444
/var/www/api/bootstrap/compiled.php:4763
/var/www/api/bootstrap/compiled.php:7834
/var/www/api/bootstrap/compiled.php:7821
/var/www/api/bootstrap/compiled.php:4775
/var/www/api/bootstrap/compiled.php:483
/var/www/api/bootstrap/compiled.php:490
/var/www/api/vendor/symfony/http-kernel/Symfony/Component/HttpKernel/Client.php:82
/var/www/api/vendor/symfony/browser-kit/Symfony/Component/BrowserKit/Client.php:324
/var/www/api/vendor/laravel/framework/src/Illuminate/Foundation/Testing/TestCase.php:58
/var/www/api/app/tests/controllers/AuthControllerTest.php:22
/usr/share/php/PHPUnit/TextUI/Command.php:192
/usr/share/php/PHPUnit/TextUI/Command.php:130

FAILURES!                                                                                              
Tests: 41, Assertions: 38, Errors: 1.    

这里是errors.php文件:

<?php

class PermissionException extends Exception {

    public function __construct($message = null, $code = 403)
    {
        parent::__construct($message ? : 'Action not allowed', $code);
    }

}

class ValidationException extends Exception {

    protected $messages;

    public function __construct($validator)
    {
        $this->messages = $validator->messages();
        parent::__construct($this->messages, 400);
    }

    public function getMessages()
    {
        return $this->messages;
    }

}

class NotFoundException extends Exception {

    public function __construct($message = null, $code = 404)
    {
        parent::__construct($message ? : 'Resource Not Found', $code);
    }

}

最后,我的 composer.json 文件:

{
        "name": "laravel/laravel",
        "description": "The Laravel Framework.",
        "keywords": ["framework", "laravel"],
        "require": {
            "laravel/framework": "4.0.*",
            "way/generators": "dev-master",
            "twitter/bootstrap": "dev-master",
            "conarwelsh/mustache-l4": "dev-master",
            "hybridauth/hybridauth": "*"
        },
        "require-dev": {
            "phpunit/phpunit": "3.7.*",
            "mockery/mockery": "0.7.*"
        },
        "autoload": {
                "classmap": [
                        "app/commands",
                        "app/controllers",
                        "app/models",
                        "app/database/migrations",
                        "app/database/seeds",
                        "app/tests/TestCase.php",
                        "app/ifr/interfaces",
                        "app/ifr/repositories",
                        "app/errors.php"
                ]
        },
        "scripts": {
            "post-install-cmd": [
                "php artisan optimize"
            ],
            "pre-update-cmd": [
                "php artisan clear-compiled"
            ],
            "post-update-cmd": [
                "php artisan optimize"
            ],
            "post-create-project-cmd": [
                "php artisan key:generate"
            ]
        },
        "config": {
                "preferred-install": "dist"
        },
        "minimum-stability": "dev"
}

【问题讨论】:

  • 你的作曲家自动加载部分到底有什么?
  • 您在哪个服务器/系统上运行它?也许存在某种本地缓存或类似问题?

标签: php laravel laravel-4


【解决方案1】:

尝试以下方法:

  • 创建 errors.php 文件并编写异常代码
  • 将文件放入根 composer.json 的 autload 部分
  • 在你的 laravel 根目录中运行:

    php composer.phar dump-autoload
    
    php artisan clear-compiled
    
    php artisan optimize
    

请报告:)

【讨论】:

  • 我按照这些步骤将结果添加到问题中。
  • 从 laravel 5.6 弃用的 php artisan 优化。
【解决方案2】:

它很旧,但有人可能需要解决问题。请删除compiled.php,然后运行composer update。应该没问题。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2021-04-05
    • 1970-01-01
    • 2021-03-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多