Laravel 文档多次上传未保存到数据库

Posted

技术标签:

【中文标题】Laravel 文档多次上传未保存到数据库【英文标题】:Laravel Documents Multiple Upload Not Saved to Database 【发布时间】:2021-11-01 10:55:29 【问题描述】:

我想上传每个产品的文档/附件并将它们存储在公共文件夹中,其中文档可以是 pdf、图像和 csv。我能够上传公共文件夹中的多个文件,但没有将文件的数据保存到数据库中。

型号

protected $fillable = [
  'product_id',
  'name',
  'price',
  'file',
  'publish',
];

控制器

public function store(Request $request)         
    $request->validate([
        'name' => 'required',
        'product_id' => 'required',
        'price' => 'required',
        'file' => 'required',
        'file.*' => 'mimes:jpeg,jpg,png,gif,csv,txt,pdf|max:2048',
        'publish' => 'required',
    ]);

    $fileData = [];
    if($request->hasFile('file')) 
        foreach($request->file('file') as $file) 
            $fileName = time().'_'.$file->getClientOriginalName();
            $file->move(public_path('storage/documents/'), $fileName);
            $fileData[] = $fileName;
        
    

    $doc = new Document();
    $doc->name = $request->name;
    $doc->product_id = $request->product_id;;
    $doc->price = $request->price;
    $doc->file = json_encode($fileData);
    $doc->publish = $request->publish;

    dd($doc);

    $doc->save();
    
    return redirect()->route('product.index');

https://imgur.com/a/FDMQMLS

刀片视图

<div class="form-group">
    <label>Document</label>
    <div class="input-group-append">
        <label for="upload_file" class="btn btn-info">Upload</label>
        <input id="upload_file" type="file" name="file[]" multiple>
    </div>
    <div id="document"></div>
</div>

【问题讨论】:

【参考方案1】:

请检查您的文件字段的数据类型。 您也可以使用 serialize()/unserialize() 方法。

$data = serialize(["file1", "file2"]);
echo $data;

【讨论】:

以上是关于Laravel 文档多次上传未保存到数据库的主要内容,如果未能解决你的问题,请参考以下文章

Laravel 多次上传图像预览然后裁剪

Laravel:如何通过 API postman 上传图像并将其保存到数据库(phpmyadmin)

上传图片到 Laravel-Lumen API

只有 JSON 中的第一个值保存到数据库 - Laravel

laravel 收不到iOS上传的文件

读取excel文件并上传到数据库Laravel 5