如何通过 Axios 发送文件到 Laravel

How to send a file via Axios to Laravel

我需要 post 通过 Axios 从客户端到服务器的文件。

这是我的 Vuejs 代码:

methods: {
    'successUpload': function (file) {
        const config = { headers: { 'Content-Type': 'multipart/form-data' } };
        axios.post('/Upload/File',file, config).then(function (response) {
            console.log(response.data);
        });
    }
}

这是我的 Laravel 处理发送文件的代码:

public function uploadFile(Request $request)
{
    if($request->hasFile('file'))
      return "It's a File";

    return "No! It's not a File";
}

但它总是returns No It's not a File

任何帮助将不胜感激。

您必须创建一个 FormData 对象并附加图像文件。

methods: {
  'successUpload': function (file) {

    let data = new FormData();
    data.append('file', document.getElementById('file').files[0]);

    axios.post('/Upload/File',data).then(function (response) {
        console.log(response.data);
    });
  }
}

一个例子是here

如果可行,请告诉我。