загрузка multer / filepond, возвращающая undefined

В настоящее время я пытаюсь интегрировать несколько компонентов / экземпляров файла в свое приложение для реагирования, где изображения загружаются при отправке кнопки / формы.

У меня он более или менее работает с приведенным ниже кодом, но я получаю неопределенный результат при выходе из системы в файле routes.js, хотя когда я выхожу из состояния при отправке в upload.js, я получаю результаты .

Я пробовал выйти из системы только req.files, он возвращает undefined, метод, который я использовал ниже, взят непосредственно из документации multers, и он выходит из системы - TypeError: невозможно прочитать свойство '0' of undefined

Спасибо

upload.js

import React, { useState } from "react";
import ReactDOM from "react-dom";
import axios from "axios";
import "./styles.css";

import { FilePond, registerPlugin } from "react-filepond";
import "filepond/dist/filepond.min.css";
// import FilePondPluginFileEncode from 'filepond-plugin-file-encode';
import FilePondPluginImageExifOrientation from "filepond-plugin-image-exif-orientation";
import FilePondPluginImagePreview from "filepond-plugin-image-preview";
import "filepond-plugin-image-preview/dist/filepond-plugin-image-preview.css";

// Register the plugins
registerPlugin(FilePondPluginImageExifOrientation, FilePondPluginImagePreview);

const API_BASE = "http://localhost:5000";

function submitForm(contentType, data, setResponse) {
  axios({
    url: `${API_BASE}/upload`,
    method: "POST",
    data: data,
    headers: {
      "Content-Type": contentType
    }
  })
    .then(response => {
      setResponse(response.data);
    })
    .catch(error => {
      setResponse("error");
    });
}

function App() {
  const [title, setTitle] = useState("");
  const [file, setFile] = useState("");
  const [file3, setFile3] = useState("");
  const [desc, setDesc] = useState("");

  function uploadWithFormData() {
    const formData = new FormData();
    formData.append("title", title);

    formData.append("file", file);

    formData.append("file3", file3);

    formData.append("desc", desc);

    submitForm("multipart/form-data", formData, msg => console.log(msg));
  }

  return (
    <div className="App">
      <h2>Upload Form</h2>
      <form>
        <label>
          File Title
          <input
            type="text"
            vaue={title}
            onChange={e => {
              setTitle(e.target.value);
            }}
            placeholder="Give a title to your upload"
          />
        </label>

        <FilePond
          name={file}
          files={file}
          allowMultiple={false}
          server={null}
          instantUpload={false}
          onupdatefiles={setFile}
        />

        <FilePond
          name={file3}
          files={file3}
          allowMultiple={false}
          server={null}
          instantUpload={false}
          onupdatefiles={setFile3}
        />

        <label>
          Description
          <textarea value={desc} onChange={e => setDesc(e.target.value)} />
        </label>

        <input
          type="button"
          value="Upload as Form"
          onClick={uploadWithFormData}
        />
      </form>
    </div>
  );
}

const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);

routes.js

router.post('/', upload.fields([{ name: 'file'}, { name: 'file3' }]), (req, res) => {

 console.log(req.files['file'][0]);
 console.log(req.files['file3'][0]);

  var movieData = {
    desc: req.body.desc,
    title: req.body.title,
    imgCollection:  req.files['file'],
    poster: req.files['file3']
  };

  Movie.create(movieData)
    .then(movie => res.json({ msg: 'Movie added successfully' }))
    .catch(err => res.status(400).json({ error: 'Unable to add this movie' }));
});

образ журнала консоли

журнал консоли upload.js


person old_blueyes    schedule 01.12.2019    source источник


Ответы (2)


То, что вы регистрируете, - это элемент файла FilePond, а не объект File. Элемент файла имеет свойство file, которое содержит фактический объект файла. Если зарегистрированный вами массив - это то, что вы отправляете на сервер, вам необходимо сопоставить его, чтобы он содержал объекты файла вместо файловых элементов FilePond.

person Rik    schedule 02.12.2019

Вы не должны передавать Content-type в заголовках.

Получите свойство файла из файлов при добавлении, как показано ниже,

formData.append("file", files.file);
person Sudhakar    schedule 02.09.2020