VueJS-Axios: при загрузке файла изображения на локальный хост выдается ошибка: POST 404 (не найден).Зачем? - PullRequest
0 голосов
/ 08 июля 2019

У меня очень простое приложение VueJS Axios для понимания загрузки файлов через Axios, однако файл не сохраняется в каталог http://localhost/upload.

Я получаю 2 ошибки:

POST http://localhost:8080/upload 404 (Not Found)

и

createError.js?f777:16 Uncaught (in promise) Error: Request failed with status code 404
    at createError (eval at <anonymous> (build.js:1359), <anonymous>:16:15)
    at settle (eval at <anonymous> (build.js:1442), <anonymous>:17:12)
    at XMLHttpRequest.handleLoad (eval at <anonymous> (build.js:1338), <anonymous>:59:7)

Вот полный код:

<template>
  <div id="app">
    <input type="file" @change="getFile">
    <button @click="uploadFile">Upload file</button>
  </div>
</template>

<script>

import axios from 'axios'

export default {
  name: "App",

  data() {
    return {
      selectedFile: null
    }
  },

  methods: {
    getFile() {
      let file = event.target.files[0]
      this.selectedFile = file
    },
    uploadFile() {
        let fd = new FormData()
        fd.append('image', this.selectedFile, this.selectedFile.name)
        axios.post('/upload', fd)
          .then(res => {
              console.log(res);
          })
    }
  }
}
</script>

Обновлен

серверкод стороны (formidable.js)

var http = require('http');
var formidable = require('formidable');
var fs = require('fs');

http.createServer(function (req, res) {
  res.setHeader("Access-Control-Allow-Origin", "*")
  res.setHeader("Content-Type", 'text/html');
  console.log("TRIGGERED");
  if (req.url == '/fileupload') {
    var form = new formidable.IncomingForm();
    form.parse(req, function (err, fields, files) {
      var oldpath = files.filetoupload.path;
      var newpath = 'C:/Users/Admin/Desktop/uploadTest/' + files.filetoupload.name;
      fs.rename(oldpath, newpath, function (err) {
        if (err) throw err;
        res.write('File uploaded and moved!');
        res.end();
      });
 });
  } else {
    res.writeHead(200, {'Content-Type': 'text/html'});
    res.write('<form action="fileupload" method="post" enctype="multipart/form-data">');
    res.write('<input type="file" name="filetoupload"><br>');
    res.write('<input type="submit">');
    res.write('</form>');
    return res.end();
  }
}).listen(9090);

Обновленная сторона клиента:

<template>
  <div id="app">
    <input type="file" @change="getFile">
    <button @click="uploadFile">Upload file</button>
  </div>
</template>

<script>

import axios from 'axios'

export default {
  name: "App",

  data() {
    return {
      selectedFile: null
    }
  },

  methods: {
    getFile() {

      let file = event.target.files[0]
      this.selectedFile = file
    },
    uploadFile() {
        let fd = new FormData()
        fd.append('myImg', this.selectedFile, this.selectedFile.name)
        axios.post('http://localhost:9090/formidable', fd)
          .then(res => {
              console.log(res);
          })
    }
  }
}
</script>

Проблема с кодом на стороне сервера заключается в том, что я не знаю, как получить данные файлаотправлено на сервер.Этот console.log («TRIGGERED») запускается, но не может выйти за пределы этого.

спасибо

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