【uniapp】上传附件+Java后端

一、背景

移动端项目使用uniapp开发,项目有上传附件的需求。现在分享给大家,一起进步

二、前端

关键代码:

uni.chooseFile({
	type: "all",
	count: this.count,
	success: res => {
		let len = 0;
		res.tempFiles.forEach((item, index) => {
			len++;
			let info = {
				filename: item.name,
				filepath: item.path,
				filetype: this.fileHz(item.name),
				file: item
			}
			let flag = /\.(doc|docx|xls|xlsx|ppt|pdf|zip|rar|jpg|png|jpeg)$/
				.test(
					item.name.toLowerCase())
			//双重保证
			if (this.size <= info.file.size) {
				this.$toast("文件最大不超过2M");
				return
			}
			if (flag) {
				this.upload(material, info, index1);
			} else {
				this.$toast("请选择.doc、.docx、.xls、.xlsx、.ppt、.pdf、.zip、.rar格式文件")
				return
			}
		})
	},
	fail: err => {
		console.log(err);
	}
});

/* 截取后缀名 */
fileHz(name) {
	//获取最后一个.的位置
	var index = name.lastIndexOf(".");
	//获取后缀
	var ext = name.substr(index + 1);
	return ext
},

发送请求接口:

upload(material, info, index) {
	const formData = new FormData();
	if (!info) {
		this.$toast('请上传文件');
		return;
	}
	formData.append('file', info.file);
	let para = {
		//这是额外的参数
	}
	formData.append("para", JSON.stringify(para));
	
	uni.uploadFile({
		url: 'htpp:127.0.0.1:8080/xxx/xxxx/xxxxx', //仅为示例,非真实的接口地址
		filePath: info.file.path,
		name: 'file',
		formData: {
			para: JSON.stringify(para)
		},
		success: (uploadFileRes) => {
			this.$toast("上传成功");
		},
		fail: (err) => {
			this.$toast("提交失败:" + err);
		},
},

三、后端

关键代码:

java 复制代码
public void uploadMaterial(HttpServletRequest request, HttpServletResponse response, JSONObject parado) throws Exception {
    response.setContentType("text/html;charset=UTF-8");
    JSONObject result = new JSONObject();
    try {
        // 处理入参
        JSONObject para = JSONObject.parseJSON(parado.getString("para"));
        MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
        CommonsMultipartFile file = (CommonsMultipartFile) multipartRequest.getFile("file");
        if(file != null){
            InputStream stream = file.getInputStream();
            String filename = file.getOriginalFilename();
            String filetype = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".") + 1);
            byte[] b= IoUtil.getBytes(stream);
            String base64 = Base64Encoder.encode(b);
            para.put("base64",base64);
            para.put("wjmc",filename);
            para.put("type",filetype);
        }
     
    } catch (BusinessException e) {
        logger.error("上传材料失败", e);
      
    } catch (Exception e) {
        logger.error("上传材料失败", e);
    }
	......
}
相关推荐
何中应3 分钟前
Spring Boot中选择性加载Bean的几种方式
java·spring boot·后端
苏苏大大5 分钟前
zookeeper
java·分布式·zookeeper·云原生
阿俊仔(摸鱼版)7 分钟前
Python 常用运维模块之OS模块篇
运维·开发语言·python·云服务器
军训猫猫头7 分钟前
56.命令绑定 C#例子 WPF例子
开发语言·c#·wpf
sunly_14 分钟前
Flutter:自定义Tab切换,订单列表页tab,tab吸顶
开发语言·javascript·flutter
远方 hi24 分钟前
linux虚拟机连接不上Xshell
开发语言·php·apache
wclass-zhengge32 分钟前
03垃圾回收篇(D3_垃圾收集器的选择及相关参数)
java·jvm
涛ing33 分钟前
23. C语言 文件操作详解
java·linux·c语言·开发语言·c++·vscode·vim
NoneCoder34 分钟前
JavaScript系列(42)--路由系统实现详解
开发语言·javascript·网络
半桔38 分钟前
栈和队列(C语言)
c语言·开发语言·数据结构·c++·git