uni.uploadFile上传图片后台接收不到数据

今天遇到一个很奇怪的问题,通过使用uni.uploadFile上传文件时后端接收不到文件,查过很多资料,原来是自定义了header的Content-Type问题。取消即可,另把自定义文件上传的代码贴出来。

分析:当我们加上请求头的时候 

不加请求头的时候

浏览器会默认帮我们加上请求头,并且默认加上一串boundary信息。

使用'multipart/form-data'需要不需要设置浏览器会自己设置,因为我们设置Content-type会覆盖浏览器自己设置的值,我们不知道formData对象里面的boundary分隔符是什么,所以就会导致后端接受到数据以后在Content-type中找不到boundary或者boundary的值与formData中的boundary不一致,导致无法获取正确的数据

上传文件插件

  <uni-file-picker file-extname="jpg,jpeg,gif,png" @select="selectFile"  ref="files" :auto-upload="false"  limit="1" fileMediatype="image"/>

select文件动作保存文件信息

methods: {
            selectFile(e){this.fileInfo=e.tempFiles[0];},
            ......
        }
uni.uploadFile(
                        {
                            url:"https://www.chinayq.com/api/user/user.ashx",
                            filePath:that.fileInfo.url,
                            name:"file",
                            header: {
                            //"Content-Type": "multipart/form-data", // 不要自定义Content-Type头
                            "token": uni.getStorageSync('token') // token验证
                            },
                            //formData:that.formData,
                            success:function(res)
                            {
                                
                            }
                            
                        });        
                    })}

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用 `uni.uploadFile` 方法来上传视频,并接收上传的结果。这个方法是在 uni-app 框架中使用的,用于将文件上传到服务器。 在使用 `uni.uploadFile` 方法时,你需要提供以下参数: - `url`:上传的目标 URL。 - `filePath`:要上传的文件路径。 - `name`:上传文件的字段名。 - `success`:上传成功后的回调函数。 - `fail`:上传失败时的回调函数。 下面是一个示例代码,演示如何使用 `uni.uploadFile` 上传视频文件: ```javascript uni.chooseVideo({ success: function (res) { // 选择视频成功 var tempFilePath = res.tempFilePath; // 视频临时文件路径 uni.uploadFile({ url: 'https://example.com/upload', // 替换为实际的上传 URL filePath: tempFilePath, name: 'video', success: function (res) { // 上传成功 console.log(res.data); // 上传结果 }, fail: function (err) { // 上传失败 console.log(err); } }); } }); ``` 上述代码中,我们首先使用 `uni.chooseVideo` 方法选择要上传的视频文件。然后,我们将选择的视频文件路径传递给 `uni.uploadFile` 方法的 `filePath` 参数。接着,我们指定了上传文件的字段名为 `'video'`,并提供了成功和失败的回调函数。 请注意,你需要将 `'https://example.com/upload'` 替换为实际的上传 URL,以便将视频文件上传到服务器。此外,你还可以根据需要自定义其他参数,例如设置请求头、表单数据等。 希望这个示例能帮助到你!如果你还有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值