首页 > 解决方案 > Laravel:存储文件时“无法创建根目录”

问题描述

我正在尝试通过 AJAX 将文件存储到 laravel 中的公用文件夹,但是当我提交表单时,我收到以下消息:

" 消息:"无法创建根目录 \"C:\xampp\htdocs\Restaurante1\storage\app\C:/xampp/htdocs/Restaurante1/public/img\"。",异常:"League\Flysystem\Exception ", 文件: "C:\xampp\htdocs\Restaurant1\vendor\league\flysystem\src\Adapter\Local.php"

我正在尝试将文件存储到公共目录内的以下文件夹中:public > img >uploads

这是我的 JQuery 代码:

console.log('new slider button clicked');
	
var formData = new FormData();
formData.append('title', $('#sliders_title').val());
formData.append('body', $('#sliders_body').val());
formData.append('isVisible', $('#sliders_isVisible').is(':checked') ? 1 : 0);
formData.append('image', $('#sliders_image').prop('files')[0]);


$.ajax({

    async: true,
    url: '/sliders',
    type: 'POST',
    data: formData,
    dataType: 'JSON',
    processData: false,
    contentType: false,
        
    success: function (data) { 
        $('.form_valid_container').html('<span class="form_valid_text">✓ '+ data.success +'</span>');
	    form.trigger("reset");
        console.log(data.success, data.errors);
    },

    error: function (data){
        var errors = data.responseJSON;
        console.log(errors);
	
	    $.each(errors , function(){
            $('.form_error_container').html('<span class="form_error_text">✘ '+ errors.message +'</span>')
        }); 
    }
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

我的控制器方法:

public function store(StoreSlider $request)
{
    $uploadFile = $request->file('image');

    //generate random filename and append original extension (eg: asddasada.jpg, asddasada.png)
    $filename = str_random(6).'.'.$uploadFile->extension();

    // storing path (Change it to your desired path in public folder)
    $path = 'img/uploads/';

    // Move file to public filder
    $uploadFile->storeAs(public_path($path), $filename);
	
    $slider = new Slider();
    $slider->title = $request->title;
    $slider->body = $request->body;
    $slider->image = $path.'/'.$filename; // So that you can access image by url($slider->image);
    $slider->isVisible = $request->isVisible;
    $slider->save();
	
    return response()->json([
	
        'success' => 'Diapositiva guardada correctamente',
		'slider' => $slider,
    ]);
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

编辑:这是我的配置/文件系统

<?php

return [

    /*
    |--------------------------------------------------------------------------
    | Default Filesystem Disk
    |--------------------------------------------------------------------------
    |
    | Here you may specify the default filesystem disk that should be used
    | by the framework. The "local" disk, as well as a variety of cloud
    | based disks are available to your application. Just store away!
    |
    */

    'default' => env('FILESYSTEM_DRIVER', 'local'),

    /*
    |--------------------------------------------------------------------------
    | Default Cloud Filesystem Disk
    |--------------------------------------------------------------------------
    |
    | Many applications store files both locally and in the cloud. For this
    | reason, you may specify a default "cloud" driver here. This driver
    | will be bound as the Cloud disk implementation in the container.
    |
    */

    'cloud' => env('FILESYSTEM_CLOUD', 's3'),

    /*
    |--------------------------------------------------------------------------
    | Filesystem Disks
    |--------------------------------------------------------------------------
    |
    | Here you may configure as many filesystem "disks" as you wish, and you
    | may even configure multiple disks of the same driver. Defaults have
    | been setup for each driver as an example of the required options.
    |
    | Supported Drivers: "local", "ftp", "sftp", "s3", "rackspace"
    |
    */

    'disks' => [

        'local' => [
            'driver' => 'local',
            'root' => storage_path('app'),
        ],

        'public' => [
            'driver' => 'local',
            'root' => storage_path('app/public'),
            'url' => env('APP_URL').'/storage',
            'visibility' => 'public',
        ],

        's3' => [
            'driver' => 's3',
            'key' => env('AWS_ACCESS_KEY_ID'),
            'secret' => env('AWS_SECRET_ACCESS_KEY'),
            'region' => env('AWS_DEFAULT_REGION'),
            'bucket' => env('AWS_BUCKET'),
            'url' => env('AWS_URL'),
        ],

    ],

];
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

标签: phpjqueryajaxlaravel

解决方案


我的回答可能与这个问题无关,但如果有人遇到同样的问题,我认为可能会有所帮助。我遇到了同样的问题,我“ putFileAs ”的工作方式与“ storeAs ”的工作方式相同,所以$path = Storage::putFileAs('public/users_upload/'.$user->username, $File_to_be_moved, $file_name_to_store_as);第一个参数是您目录的路径...您可以在此处查看 laravel 文档以获取更多信息


推荐阅读