Laravel 错误:include (**) failed to open stream: No such file 排查

问题描述

在laravel开发过程中,运行发现错误信息如下:

include(/Library/WebServer/Documents/local.laravel.com/api-laravel/vendor/composer/../../app/Models/CheckProductT.php): failed to open stream: No such file or directory

查看代码:

namespace App\Http\Controllers\Apis;

use App\Models\CheckWarehouseT;
use App\Http\Controllers\Controller;

class TestController extends Controller
{
    public function test2()
    {
        $check = new CheckWarehouseT();
        $check->batch_number="201905-001";//盘库号
        $check->save();
    }
}

报错信息来自于

$check = new CheckWarehouseT();

查看use

use App\Models\CheckWarehouseT;

到对应的位置查看model文件

namespace App\Models;

use Illuminate\Database\Eloquent\Model;

class CheckWarehouseT extends Model
{
    //
    protected $table = 'check_warehouse_t';
}

对应位置的文件也是存在的。使用编辑器的快速定位,同样能够找到对应的文件,但是还是报文件或文件夹不存在的错误。
仔细查看错误信息未找到的文件是:CheckProductT.php
与我们代码中的文件:CheckWarehouseT.php不是同一个。但是报错的位置是没有错误的。这有可能是我刚刚妆model文件的名字由CheckProductT.php改成CheckWarehouseT.php造成的。没有在其它地方使用这个model.
在项目中查找:CheckProductT发现,在文件:/Library/WebServer/Documents/local.laravel.com/api-laravel/vendor/composer/autoload_static.php 中有代码

'App\\Models\\CheckWarehouseT' => __DIR__ . '/../..' . '/app/Models/CheckProductT.php',

在文件:/Library/WebServer/Documents/local.laravel.com/api-laravel/vendor/composer/autoload_classmap.php 中有代码

'App\\Models\\CheckWarehouseT' => $baseDir . '/app/Models/CheckProductT.php',

显名前后无法对应。意思就是当你使用CheckWarehouseT这个类时,laravel自动加载的文件是CheckProductT.php这个文件。

解决方案

有两种,一种是手动修改这两个文件将代码改成:

'App\\Models\\CheckWarehouseT' => __DIR__ . '/../..' . '/app/Models/CheckWarehouseT.php',
'App\\Models\\CheckWarehouseT' => $baseDir . '/app/Models/CheckWarehouseT.php',

另外一种就是运行命令:重新生成自动装载文件。

composer dump-autoload

关于为什么总要运行 composer dump-autoload,参见:分享:深入 Composer autoload 说的很详细。

《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 1

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!