Laravel: Dropzone JS, получение [объект объекта], но почему? - PullRequest
0 голосов
/ 24 мая 2018

Я пытаюсь загрузить изображение с помощью Dropzone.js в Laravel, но у меня появляется ошибка, показывающая [object Object] на моих миниатюрах после загрузки фотографии.Я не могу найти свою ошибку и не понимаю, в чем причина.

Вот мой код и изображение ошибки.Почему это происходит?Что я могу сделать?

enter image description here

Просмотр:

<div class="container col-md-8 col-12 mx-auto">
        <div class="row">
            <div class="col-sm-10 offset-sm-1">
                <h2 class="page-heading">Upload your Images <span id="counter"></span></h2>
                <form method="post" action="{{ url('/addimage') }}"
                      enctype="multipart/form-data" class="dropzone" id="my-dropzone">
                    {{ csrf_field() }}
                    <div class="dz-message">
                        <div class="col-xs-8">
                            <div class="message">
                                <p>Drop files here or Click to Upload</p>
                            </div>
                        </div>
                    </div>
                    <div class="fallback">
                        <input type="file" name="file" multiple>
                        <input type="hidden" name="id" value="{{$id}}" >
                    </div>
                </form>
            </div>
        </div>
    </div>

Маршрут:

Route::group(['middleware'=>'auth'], function (){
...
Route::post('/addimage', 'FrontendController@addimage');
Route::post('/adddeleteimage', 'FrontendController@adddeleteimage');
...
});

Контроллер:

public function addimage(Request $request){
    $file = $request->file('file');
    $filename = uniqid().".".$file->clientExtension();
    $file->move('img/product', $filename);


    $dropzone = new Imagedb;
    $dropzone->product_id = $request->id;
    $dropzone->url = 'img/product'.$filename;

    $dropzone->save();
}

JS:

var total_photos_counter = 0;
    Dropzone.options.myDropzone = {
        uploadMultiple: true,
        parallelUploads: 2,
        maxFilesize: 16,
        acceptedFiles: "image/*",
        resizeWidth: 360,
        previewTemplate: document.querySelector('#preview').innerHTML,
        addRemoveLinks: true,
        dictRemoveFile: 'Remove file',
        dictFileTooBig: 'Image is larger than 16MB',
        timeout: 10000,

        init: function () {
            this.on("removedfile", function (file) {
                $.post({
                    url: '/adddeleteimage',
                    data: {id: file.name, _token: $('[name="_token"]').val()},
                    dataType: 'json',
                    success: function (data) {
                        total_photos_counter--;
                        $("#counter").text("# " + total_photos_counter);
                    }
                });
            });
        },
        success: function (file, done) {
            total_photos_counter++;
            $("#counter").text("# " + total_photos_counter);
        }
    };

Ответы [ 2 ]

0 голосов
/ 01 марта 2019

Я исправил эту ошибку, добавив в заголовок тега

<meta name="csrf-token" content="{{ csrf_token() }}"> 

и в конфигурации инициализации dropzone

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

Пример:

  autoProcessQueue:false,
  required:true,
  acceptedFiles: ".png,.jpg,.gif,.bmp,.jpeg",
  addRemoveLinks: true,
  maxFiles:8,
  parallelUploads : 100,
  maxFilesize:5,
  headers: { 'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content') }
0 голосов
/ 24 мая 2018

Во-первых, попробуйте $ ('meta [name = "csrf-token"]'). Attr ('content') как токен

...