Отправка изображения через Ajax для Multer - PullRequest
0 голосов
/ 01 октября 2019

Я использую Multer для загрузки файла изображения на сервер моего узла, и всегда возвращаюсь к тому, что я не могу определить, как использовать ajax для отправки изображения.

Ajax:

image = $("#input-file-img").val()
                const data = new FormData();
                 data.append("image", image);
                 $.ajax({
                    url: '/uploadfile/' + userName,
                    method: 'POST',
                    async: false,
                    processData: false ,
                    contentType: false,
                    data: data
                })

Upload.js

var storage = multer.diskStorage({
  destination: function (req, file, cb) {
    cb(null, 'uploads')
  },
  filename: function (req, file, cb) {
    cb(null, file.originalname)
  }
})
var upload = multer({ storage: storage })

router.post('/uploadfile/:userName', upload.single('image'), async (req, res, next) => {
  let user = await User.findOne({ userName: req.params.userName })
  let file = req.file
  let fileName = file.filename
  let path = variables.kepler + 'uploads/' + fileName
  user.image = path
  await user.save()
  if (!path) {
    const error = new Error('Please upload a file ...')
    error.httpStatusCode = 400
    return next(error)
  }

  if (path) {
    return res.status(200).send({
      status: '200',
      message: 'Operation completed successfully ...',
      data: user,
      path
    })
  }
})

Я проверил значение изображения с консоли, и оно показывает C: \ fakepath \ Capture d'écran de 2019-09-19 11-33-59.png '

Буду признателен за любую помощь.

Ответы [ 2 ]

1 голос
/ 01 октября 2019

Я думаю, что ваш код на стороне сервера в порядке, если я изменю код на стороне клиента, как показано ниже, все работает хорошо, в итоге мы получим изображения в папке / uploads:

function base64toBlob(base64, mimeType) {
    const bytes = atob(base64.split(',')[1]);
    const arrayBuffer = new ArrayBuffer(bytes.length);
    const uintArray = new Uint8Array(arrayBuffer);
    for (let i = 0; i < bytes.length; i++) {
        uintArray[i] = bytes.charCodeAt(i);
    }
    return new Blob([ arrayBuffer ], { type: mimeType });
}

function submitForm() {         
    const imgRegEx = /^data:(image\/(gif|png|jpg|jpeg))/;
    const imageData = $('#input-file-img').attr('src');
    const mimeType = imgRegEx.exec(imageData)[1];
    const blob = base64toBlob(imageData, mimeType);

    const fileExt = mimeType.replace("image/", "");
    const fileName = "test-image." + fileExt; // Change as appropriate..

    const data = new FormData();
    data.append("image", blob, fileName);

    $.ajax({
        url: '/uploadfile/' + userName,
        method: 'POST',
        async: false,
        processData: false ,
        contentType: false,
        data: data
    })
}
0 голосов
/ 01 октября 2019

Решено !!!

получение значения по

image = $("#input-file-img").val()

, что означает, что я отправлял тип String в виде файла

, поэтому мне пришлось изменить его на

image = $('#input-file-img')[0].files[0]

и все работает очень хорошо

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...