Многократная загрузка изображений с Laravel - PullRequest
0 голосов
/ 08 января 2019

Я работаю над тем, чтобы сделать мультизагрузку изображения в базу данных с помощью средства изменения размера вмешательства в Laravel.

Это то, что я сейчас пишу в моем контроллере imgProdukProc контроллер:

use Illuminate\Http\Request;
use File;
use Image;
use App\imgProd;

.....

public function store(Request $request)
    {
        if($request->hasFile('img')){
            foreach ($request->file('img') as $image) {
            if ($image->isValid()) {

                $img = new imgProd();
                $image_name = uniqid() .'.'. $image->getClientOriginalExtension();
                $path = public_path('/img/prod');
                $imgx = Image::make($image->getRealPath());
                $imgx->resize(360, 360, function ($constraint) {
                $constraint->aspectRatio();
                })->save($path.'/'.$image_name);

                $img->id_prod = $request->get('id_prod');
                $img->pics = 'img/prod/'.$image_name;

                $date=date_create('now');
                $format = date_format($date,"Y-m-d");
                $img->date = $format;
                $img->save();
                return redirect('adminImgProd')->with('success', 'Picture successfully added ');
            }
        }          
    }
}

и это мои взгляды

Просмотры adminImgProd

<form enctype="multipart/form-data" action="{{url('adminImgProd')}}" method='post'>
@csrf

<div class="form-group">
<label>CODE PRODUCT</label>
<div class="input-group">
<span class="input-group-addon"><span class="glyphicon glyphicon-pencil"></span></span>
<input type="text" autocomplete="off" class="form-control" id='id_prod' name='id_prod' required="required" />
<span class="input-group-addon"><button type="button" onClick="javascript:openWindow2();">Select</button></span>
</div>
</div>

<div class="form-group">
<label>IMAGE PRODUCT</label>
<div class="input-group">
<span class="input-group-addon"><span class="glyphicon glyphicon-pencil"></span></span>
<input multiple type="file" class="form-control" name='img[]' id='file-input' required="required" /></div>
</div>

Код выше работает, но почему-то, когда я пытался загрузить 2 изображения или 3 изображения, единственное изображение, сохраненное как в целевой папке, так и в базе данных, было только одно, и это последнее

Где моя ошибка в коде, или просто мой код просто неверен с самого начала?

Заранее спасибо

Ответы [ 2 ]

0 голосов
/ 08 января 2019

Вы можете сделать следующее для нескольких изображений:

   $images = $request->file('images');

   foreach ($images as $key => $image) {
     if ($request->hasFile('images') && $request->file('images')[$key]->isValid()) {
        $path = $request->images[$key]->store('public/images');
        $path = basename($path);

        $image = new ProductImages();
        $image->product_id = $request->get('product_id');
        $image->photo = $path;
        $image->save();
      }
   }

Надеюсь, это поможет.

0 голосов
/ 08 января 2019

Вы положили return в foreach, поэтому после 1 цикла он вернется и выйдет из вашей функции:

public function store(Request $request)
{
    if ($request->hasFile('img')){
        foreach ($request->file('img') as $image) {
            if ($image->isValid()) {

                $img = new imgProd();
                $image_name = uniqid() .'.'. $image->getClientOriginalExtension();
                $path = public_path('/img/prod');
                $imgx = Image::make($image->getRealPath());
                $imgx->resize(360, 360, function ($constraint) {
                    $constraint->aspectRatio();
                })->save($path.'/'.$image_name);

                $img->id_prod = $request->get('id_prod');
                $img->pics = 'img/prod/'.$image_name;

                $date=date_create('now');
                $format = date_format($date,"Y-m-d");
                $img->date = $format;
                $img->save();
            }
        }

        return redirect('adminImgProd')->with('success', 'Picture successfully added ');
    }
}
...