Uniapp使用UviewPlus在APP当中进行文件上传的解决方案

Uniapp使用UviewPlus在APP当中进行文件上传的解决方案

吐槽:真的可以不用就不要用uniapp,就像s一样,可以的话上Recat好很多,踩了很多坑。

原因

  1. 如果你是axios的忠实奴隶那么你会遇到第一个坑,就是uniapp下的原生编译不支持FormathData数据结构这就说明你就不能使用axios来进行文件流的传输,但是这并不代表你就不能用base64来进行逆天操作。
  2. 如果使用uniapp的原生的getFileSystemManager那么很好,走到第二的坑,uniapp的app端不支持这个的来调取系统api
  3. 如果你使用功能poi来的话,非常恭喜你走到第三个坑,那就是你根本看不懂你在写的是什么s

解决方法

  1. 直接自己封装好uniapp的原生的uploadFile来进行文件的上传
  2. 注意这个的上传的方式是表表单的形式,如果你使用的是SpringBoot来做后端的话那么就直接使用pram就可以进行数据的接受了
  3. 这个注意你如果进行内网转发或者其他的代理的话你就不要想你的请求头到里面的数据还活着,所以你就必须要在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);
		}
	});
}

后端略

相关推荐
源码师傅1 天前
uniapp开源多商户小程序商城平台源码 支持二次开发+永久免费升级
小程序·uni-app·多商户商城源码·uniapp开源商城源码·开源多商户小程序商城平台·商城小程序代码·多商户商城小程序源码
梦远青城1 天前
C#地方门户网站 基于NET6.0、Admin.NET,uniapp,vue3,elementplus开源的地方门户网站项目
uni-app·开源·门户网站·地方生活网站·本地租房·本地找工作·东川本地生活
2501_915909062 天前
苹果上架App软件全流程指南:iOS 应用发布步骤、App Store 上架流程、uni-app 打包上传与审核技巧详解
android·ios·小程序·https·uni-app·iphone·webview
2501_915921432 天前
iOS 文件管理与能耗调试结合实战 如何查看缓存文件、优化电池消耗、分析App使用记录(uni-app开发与性能优化必备指南)
android·ios·缓存·小程序·uni-app·iphone·webview
小徐_23332 天前
uni-app 也能使用 App.vue?wot-starter 是这样实现的!
前端·uni-app
2501_915918412 天前
App 苹果 上架全流程解析 iOS 应用发布步骤、App Store 上架流程
android·ios·小程序·https·uni-app·iphone·webview
哆啦A梦15882 天前
uniapp分包实现
前端·vue.js·uni-app·vue3
2501_916007472 天前
苹果上架全流程详解,iOS 应用发布步骤、App Store 上架流程、uni-app 打包上传与审核要点完整指南
android·ios·小程序·https·uni-app·iphone·webview
jingling5552 天前
uniapp | 实现微信小程序端的分包处理
微信小程序·小程序·uni-app
约翰先森不喝酒2 天前
uni-app 网络请求封装实战:打造高效、可维护的HTTP请求框架
uni-app