php - 使用 Ajax 和 Laravel 5.6 上传多个图像

标签 php jquery ajax laravel image-uploading

首先,我想为我的工程师道歉。

第二我不想使用任何插件。

我想上传多张图片,不用ajax就可以做到,但我想用Ajax上传。 我把我的代码放在这里。

<form action="{{route('image-upload.store')}}" method="post" enctype="multipart/form-data">
   {{csrf_field()}}
   <input type="file" id="image-upload" name="image_upload[]" enctype="multipart/form-data" multiple>  

  <button type="submit">save</button>
</form>                          

Controller :

if ($request->hasFile('image_upload')) {
        $images = $request->file('image_upload');
        foreach ($images as $image) {
            $randonName = rand(1, 200);
            $name = $image->getClientOriginalName();
            $storename = $randonName . '_' . $name;
            $image->move(public_path('images/test'), $storename);
        }
    }

return redirect()->back();

上面的代码只是简单地上传多个图像而不使用Ajax。

这里是 Ajax :

html:

 <input type="file" id="image-upload" name="image_upload[]" enctype="multipart/form-data" multiple>

Ajax :

 $.ajaxSetup({
     headers: {'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')}
 });

$('#image-upload').change(function () {
    event.preventDefault();
    let image_upload = new FormData();
    let TotalImages = $('#image-upload')[0].files.length;  //Total Images
    let images = $('#image-upload')[0];  

    for (let i = 0; i < TotalImages; i++) {
        image_upload.append('images', images.files[i]);
    }
    image_upload.append('TotalImages', TotalImages);

    $.ajax({
        method: 'POST',
        url: '/image-upload',
        data: image_upload,
        contentType: false,
        processData: false,
        success: function (images) {
            console.log(`ok ${images}`)
        },
        error: function () {
          console.log(`Failed`)
        }
    })

})

Controller :

  if ($request->images) {
        $images = $request->images;
        $total=$request->TotalImages;
        $imagesName = $images->getClientOriginalName();
       $randonName = rand(1, 200);
        $images->move(public_path('/images/test'), $randonName . '.jpg');
        return response()->json($randonName);
    }

现在这段代码可以正常工作,但只能用于一张图像。我知道我应该将其循环并且我这样做了但没有得到我的响应。

谁能告诉我怎么做?

这是我的努力:

 if ($request->images) {
       $total=$request->TotalImages;
        $images = $request->images;
        for($j=0; $j<$total;$j++){
            $imagesName = $images->getClientOriginalName();
            $randonName = rand(1, 200);
            $images->move(public_path('/images/test'), $randonName . '.jpg');
        }
        return response()->json($randonName);
    }

  if ($request->images) {
        $images = $request->images;
        foreach ($images as $image) {
            $imagesName = $images->getClientOriginalName();
            $randonName = rand(1, 200);
            $image->move(public_path('/images/test'),$randonName . $imagesName . $randonName . '.jpg');
        }
    }

最佳答案

这也会起作用,这将发送图像数组,以便在 Controller 中轻松获取它

        for (let i = 0; i < TotalImages; i++) {
            image_upload.append('images[]', images.files[i]);
        }

关于php - 使用 Ajax 和 Laravel 5.6 上传多个图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51455679/

相关文章:

php - 为 Gmail 创建跟踪像素

javascript - 获取当前页面标题的 jQuery/Javascript 方法,将其与字符串匹配,将类分配给该特定元素

jquery - Onchange 函数在 Jquery 中不起作用

javascript - Rails 在旧形式而不是模态上显示错误

php - 推荐一个不错的非第三方简易聊天室

php - HTML 未加载到 PHP 文档中

php - 使用 mysql_fetch_array 检索字段值

PHP 无法工作,但 iframe 工作正常

javascript - 为什么第二个链接点击重定向到部分而不是对话框

ajax - 来自 Node.js 的基本警报