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 说的很详细。
可以 解决了 谢谢