繁体   English   中英

如何使用 JavaScript 和 FastAPI 上传多个文件?

[英]How can I upload multiple files using JavaScript and FastAPI?

我遵循了 FastAPI 文档,我正在尝试将用 js 编写的客户端的文件发送到用 FastAPI 编写的服务器。

我的 HTML:

<html>
    <head>
        <script src="https://code.jquery.com/jquery-2.0.3.js" integrity="sha256-lCf+LfUffUxr81+W0ZFpcU0LQyuZ3Bj0F2DQNCxTgSI=" crossorigin="anonymous"></script>
        <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
    </head>

    <body>
            <input id='fileid' type='file' value="Load miRNA data"/>
            <input id='fileid2' type='file' value="Load Target data"/>
            <input id='buttonid' type='button' value='Upload' />
    </body>
    <script type="text/javascript" src="./uplaodfiles.js"></script>
 </html>    

我的上传文件.js

document.getElementById('buttonid').addEventListener('click', generate);

function generate() {
  let file = document.getElementById("fileid").files[0];
  let file2 = document.getElementById("fileid2").files[0];
  let formData = new FormData();
  formData.append("file",file,file.name)
  formData.append("file2",file2,file2.name)
  console.log(formData)
  axios.post('http://127.0.0.1:8000/actions/upload', formData, {
    headers: {
      'content-Type': 'multipart/form-data'
    }
})
}

动作.py

from typing import List
from fastapi import APIRouter,Header,HTTPException,FastAPI, File, UploadFile

router = APIRouter()

import pandas as pd

@router.post('/upload')
def upload_file(files: List[UploadFile] = File(...)):
        print('Arrived')

    

并且无法成功获取文件,并且在服务器端出现错误:

INFO:     127.0.0.1:59210 - "POST /actions/upload HTTP/1.1" 422 Unprocessable Entity

客户:

Uncaught (in promise) Error: Request failed with status code 422
    at e.exports (isAxiosError.js:10)
    at e.exports (isAxiosError.js:10)
    at XMLHttpRequest.l.onreadystatechange (isAxiosError.js:10)

我该如何解决这个问题以及如何使用我在上传端点中收到的那些文件?

问题可能是由于您在端点需要名为files的文件List时传递了参数file1file2

我还没有测试过代码,但基本思想是用实际文件创建一个数组并将其添加到名为filesFormData中。 下面的代码应该让您了解如何实现目标。

let formData = new FormData();
formData.append("files",[file, file2]);

或者,如果我的解决方案不起作用,您可以尝试使用 formData() 上传多个文件,但同样,我的回答主要是引导您找到正确的路径。

我最近遇到了同样的问题,无法用 Isabi 提到的答案来解决。 但它给了我正确的想法:

这些文件可以彼此分开附加,重要的是两者都使用相同的名称作为参数:

formData.append('files',file)
formData.append('files',file2)

或者,如果您已经在使用文件数组:

let formData = new FormData();
for (var i = 0; i < files.length; i++){
    formData.append('files',files[i])
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM