微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决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 举报,一经查实,本站将立刻删除。