Полиморфное отношение - не может хранить все файлы в базе данных? - PullRequest
0 голосов
/ 15 сентября 2018

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

Например, я загрузил 10 изображений, все файлы перемещены в папку хранения, но в базе данных отображаются только три записи?или иногда два или четыре ..

Как это исправить?

Конфигурация Dropzone

Dropzone.options.mDropzoneTwo = {
        paramName: "images",
        maxFiles: 10,
        maxFilesize: 2, // MB
        url: '../../media/store',
        method: 'POST',
        headers: {
            "X-CSRF-TOKEN": token,
        },
        uploadMultiple: true,

        accept: function (file, done) {
            done();
        },

        init: function() {
            this.on("sending", function(file, xhr, formData){
                formData.append("post_type", post.dataset.type);
                formData.append("post_id", post.dataset.id);
            });
        },

        success: function () {
            console.log(this.files[0].xhr.responseText)
        }
    };

AdminController

public function storePostMedia(Request $request)
{
    // trying to get model by post type, there are several models depending by post types
    $table = $request->get("post_type");
    $model = getModel($table);
    // finding post
    $post = $model->find($request->get("post_id"));
    $media = new Media;
    // store images
    foreach ($request->file("images") as $image){
        $new_media = $media->storePostImages($image);
        $post->media()->save($new_media);
    }
}

storePostImages () метод

public function storePostImages($file)
{
    // get image - rename - storage to storage folder
    $realName = str_slug(pathinfo($file->getClientOriginalName(), PATHINFO_FILENAME));
    $extension = $file->getClientOriginalExtension();
    $new_name = str_slug($realName) . "-" . time() . "." . $extension;
    $fullPath = \Storage::putFileAs("posts", $file, $new_name);
    // save to database
    $this->name = $new_name;
    $this->path = $fullPath;

    return $this;
}

1 Ответ

0 голосов
/ 15 сентября 2018

Я решил свою проблему с созданием нового экземпляра модели для каждой записи

foreach ($request->file("images") as $image){ 
    $media = new Media;
    $new_media = $media->storePostImages($image);
    $post->media()->save($new_media);
}
...