React 大文件无法在移动设备上上传axios,express fileupload

问题描述

我正在将一个带有 axios 的大文件(视频 >1GB)上传到 nodejs(快速文件上传)。 可以在PC浏览器上成功上传。但是当我在移动设备上上传文件时它没有成功(api不会抛出错误

在服务器上我使用 docker。 我不确定问题是出在 react、nodejs 还是 docker 上。

我的 reactjs 代码

    if (video.length) {
        for (let i = 0; i < video.length; ++i) {
            formdata.append("videos",video[i]);
            if (i == video.length - 1) {
                axios({
                    method: "POST",url: "http://localhost:5000/addlevel",headers: { "Content-Type": "multipary/form-data" },data: formdata,onUploadProgress: (e) => {
                        if (e.lengthComputable) {
                            setLoaded((e.loaded * 100 / e.total + "%").split(".")[0])
                        }
                    }
                }).then(res => {})
            }
        }
    }

我的api代码

app.use(fileUpload({
    useTempFiles: true,tempFileDir: path.join(__dirname,'/tmp'),}))
.
.
const { videos } = req.files
async function mvFile(i) {
        return new Promise((resolve,reject) => {
            const fileName = UniqueStringGenerator.UniqueStringId() + "." + videos[i].name.split(".").slice(-1)[0];
            videos[i].mv(__dirname + "/videos/" + fileName,err => {
                    if (err) throw err;
                    resolve(fileName);
             })
         })
}

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)