Uniapp使用UviewPlus在APP当中进行文件上传的解决方案
吐槽:真的可以不用就不要用uniapp,就像s一样,可以的话上Recat好很多,踩了很多坑。
原因
- 如果你是axios的忠实奴隶那么你会遇到第一个坑,就是uniapp下的原生编译不支持FormathData数据结构这就说明你就不能使用axios来进行文件流的传输,但是这并不代表你就不能用base64来进行逆天操作。
- 如果使用uniapp的原生的getFileSystemManager那么很好,走到第二的坑,uniapp的app端不支持这个的来调取系统api
- 如果你使用功能poi来的话,非常恭喜你走到第三个坑,那就是你根本看不懂你在写的是什么s
解决方法
- 直接自己封装好uniapp的原生的uploadFile来进行文件的上传
- 注意这个的上传的方式是表表单的形式,如果你使用的是SpringBoot来做后端的话那么就直接使用pram就可以进行数据的接受了
- 这个注意你如果进行内网转发或者其他的代理的话你就不要想你的请求头到里面的数据还活着,所以你就必须要在forData的数据域里面进行数据的传输,然后这个他给你的语法糖,这个主要的功能只是进行文件的上传,你的这个也可以直接被SpringBoot来进行处理的
实现过程
vue
const uploadImagePlan = (imageList, event) => {
console.log("图片上传", event)
const fileUrl = event.file[0].url;
const base64Prefix = "data:image/jpeg;base64,"; // 根据文件类型设置前缀
console.log(fileUrl)
plus.io.resolveLocalFileSystemURL(fileUrl, (entry) => {
console.log('文件存在:', entry); // 输出条目信息
}, (error) => {
console.error('文件不存在或无法访问:', error); // 输出错误信息
});
const fileName = fileUrl.split('/').pop(); // 设置自定义的文件名
const fileExtension = fileUrl.split('.').pop(); // 获取文件扩展名
uni.uploadFile({
url: server.serverUrl() + "/uploadImage", // 后端上传接口
filePath: fileUrl,
name: "file", // 设置文件名
header: {
'file-extension': fileExtension, // 发送扩展名到后端
"fileName": fileName
},
formData: {
// 其他需要传递的表单数据
userId: '12345', // 示例字段,可以根据需求添加
fileName: fileName
},
success: (res) => {
console.log('上传成功', res);
const data = JSON.parse(res.data)
imageList.value.push({
url: data.data.fileUrl
})
},
fail: (err) => {
console.error('上传失败', err);
}
});
}
后端略