uniapp使用uni-file-picker上传图片到后端

先说思路,uni-file-picker 套 uni.uploadFile,uni-file-picker得到文件路径,uni.uploadFile上传

uniapp的uni-file-picker获得文件流的file不是二进制的文件,所以传到后端的数据只有这三个数据

fileType: image
cloudPath: 1712110487286 0.jpg
uuid: 1712110487286

所以联调后端一直出错,根本原因在于uniapp上传图片不能使用这个file,需要在使用 uni.uploadFile 上传,这里面的file才是真正的file

代码:

html5部分:

  <uni-file-picker limit="1" fileMediatype="image" @select="select"
  ></uni-file-picker>

js部分:

const coverPath = ref("");
const select = async (e) => {
  // console.log(e.tempFiles[0].file);
  let file = e.tempFiles[0];

  uni.uploadFile({
    url: proxy.Api.ShareuploadFile,
    filePath: file.path,
    formData: {
      'file': 'file'
    },
    success: (uploadFileRes) => {
      let responseData = JSON.parse(uploadFileRes.data);
      coverPath.value  = responseData.data;
      // console.log('保存的文件路径:', savedFilePath);
    }
  });
};

uni.uploadFile需要文件的路径,刚好uni-file-picker在上传完之后会返回数据,利用路径获取文件流,再上传后端,后端返回的是个对象

最后看效果:

  • 9
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于使用Uni-App的开发者来说,可以使用Uni-File-Picker组件来实现图片上传的功能。下面是一个示例代码,展示了如何使用Uni-File-Picker组件上传图片: 1. 首先在页面的vue文件中引入Uni-File-Picker组件: ``` <template> <view> <uni-file-picker :count="1" @success="uploadSuccess" @fail="uploadFail" ></uni-file-picker> <button type="primary" @click="upload">上传图片</button> </view> </template> <script> export default { methods: { uploadSuccess(files) { console.log('上传成功', files); // 在这里处理上传成功后的逻辑 }, uploadFail(err) { console.log('上传失败', err); // 在这里处理上传失败后的逻辑 }, upload() { uni.chooseImage({ count: 1, success: (res) => { const tempFiles = res.tempFiles; if (tempFiles.length > 0) { uni.uploadFile({ url: 'http://your-upload-url', filePath: tempFiles[0].path, name: 'file', success: (res) => { if (res.statusCode === 200) { const data = JSON.parse(res.data); if (data.code === 0) { this.uploadSuccess(data.files); } else { this.uploadFail(data.message); } } else { this.uploadFail('上传失败'); } }, fail: (err) => { this.uploadFail(err.errMsg); } }); } }, fail: (err) => { console.log('选择图片失败', err); } }); } } } </script> ``` 在上面的示例中,Uni-File-Picker组件用于选择图片文件,并通过`count`属性限制只能选择1张图片。当选择成功后,会触发`success`事件,调用`uploadSuccess`方法进行上传成功后的处理;当选择失败后,会触发`fail`事件,调用`uploadFail`方法进行上传失败后的处理。 在`upload`方法中,首先使用`uni.chooseImage`选择图片,并通过`uni.uploadFile`将选中的图片上传到服务器。在上传成功后,通过`uploadSuccess`方法处理上传成功后的逻辑;在上传失败后,通过`uploadFail`方法处理上传失败后的逻辑。 需要注意的是,示例中的上传接口URL需要根据实际情况进行修改。另外,还可以根据需要添加进度条等其他功能来完善上传图片的交互体验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值