Spring文件上传下载代码

Spring文件上传下载代码

文件上传

MultipartFile是SpringMVC提供简化上传操作的工具类。

	/*** 文件上传接口** @param file* @return*/@PostMapping("/fileUpload")public String fileUpload(@RequestParam("file") MultipartFile file) {// 用户鉴权,判断有无权限上传,此处逻辑省略// 文件判空if (file.isEmpty()) {return "上传失败,文件为空";}List<String> suffixList = new ArrayList<String>() {{add("pdf");add("xls");}};// 获取文件后缀String originalFilename = file.getOriginalFilename();String suffix = originalFilename.substring(originalFilename.lastIndexOf(".") + 1);// 校验文件后缀if (!suffixList.contains(suffix)) {return "文件类型不合法";}// 限制文件大小 5M , file.getSize()单位为字节if (file.getSize() > 5 * 1024 * 1024) {return "文件大小超出限制";}try {// 构建文件名// 获得当前项目所在文件夹String fileDir = System.getProperty("user.dir") + File.separator + "/file/";String fileName = "MyFile";// 首次上传需先创建文件夹File dir = new File(fileDir);if (!dir.exists()) {dir.mkdirs();}// 保存文件file.transferTo(new File(fileDir + fileDir + "." + suffix));} catch (Exception e) {return "文件上传失败";}return "文件上传成功";}

文件下载:

	@GetMapping("fileDownLoad")public void fileDownLoad(HttpServletResponse response) {FileInputStream fileInputStream = null;try{String fileName = "Myfile.exe";String absolutePath = System.getProperty("user.dir") + File.separator + "/file/" + fileName;File file = new File(absolutePath);fileInputStream = new FileInputStream(file);// 设置response 头部response.reset();response.setContentType("application/load;charset=UTF-8");//Content-Disposition的作用:告知浏览器以何种方式显示响应返回的文件,用浏览器打开还是以附件的形式下载到本地保存//attachment表示以附件方式下载 inline表示在线打开 "Content-Disposition: inline; filename=文件名.mp3"// filename表示文件的默认名称,因为网络传输只支持URL编码的相关支付,因此需要将文件名URL编码后进行传输,前端收到后需要反编码才能获取到真正的名称response.setHeader("Content-Disposition", "attachment;filename="+ new String(file.getName().getBytes("utf-8"), "iso-8859-1"));// 将输入流数据写入到响应输出流中ServletOutputStream sos = response.getOutputStream();byte[] b = new byte[1024];int len;while((len = fileInputStream.read(b)) > 0) {sos.write(b, 0, len);}} catch (Exception e) {System.out.println(e.getMessage());} finally {if(fileInputStream != null) {try{fileInputStream.close();} catch (IOException e) {System.out.println(e.getMessage());}}}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/735205.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

集合和数组的相关操作

目录 1.数组转集合(引用类型数组) 2.数组转集合(基础类型数组) 3.集合转数组 4.集合之间是否相交 5.获取两个集合的交集 6.集合转为字符串 1.数组转集合(引用类型数组) (1)Arrays.asList 示例&#xff1a; String[] colArr new String[6];colArr[0] "1";co…

代码随想录刷题笔记 DAY 42 | 最后一块石头的重量 II No.1049 | 目标和 No.494 | 一和零 No.474

文章目录 Day 4301. 最后一块石头的重量 II&#xff08;No. 1049&#xff09;<1> 题目<2> 笔记<3> 代码 02. 目标和&#xff08;No. 494&#xff09;<1> 题目<2> 笔记<3> 代码 03. 一和零&#xff08;No. 474&#xff09;<1> 题目&l…

[C/C++]string类常用接口介绍及模拟实现string类

一&#xff1a;Cstring类的由来 在C语言中&#xff0c;字符串是以\0结尾的一些字符的集合&#xff0c;为了操作方便&#xff0c;C标准库中提供了一些str系列的库函数&#xff0c;但是这些库函数与字符串是分离开的&#xff0c;不太符合OOP的思想&#xff0c;而且底层空间需要用…

字节跳动的 SDXL-LIGHTNING : 体验飞一般的文生图

TikTok 的母公司字节跳动推出了最新的文本到图像生成人工智能模型&#xff0c;名为SDXL-Lightning。顾名思义&#xff0c;这个新模型只需很轻量的推理步骤&#xff08;1&#xff0c;4 或 8 步&#xff09;即可实现极其快速且高质量的文本到图像生成功能。与原始 SDXL 模型相比&…

uniapp开发小程序实现-获取手机号码(二)

一共3篇文章,共同描述,看序号进行寻找。 真机效果图 1.前提 获取手机号码,一定要企业账号,不是企业账号会出现下面提示 所以没有企业账号的,就可以不用看了,申请企业账号去官网申请就行了,申请成功了后,我们接着看。 2.代码 代码参考文章 获取手机号 | 微信开放文…

CodecConfigurationException: Can‘t find a codec for class java.lang.Class.

前言 在使用spring data mongodb的mongoTemplate 更新数据时遇到如下错误 org.bson.codecs.configuration.CodecConfigurationException: Can’t find a codec for class java.lang.Class. 详细的错误信息 org.bson.codecs.configuration.CodecConfigurationException: Cant…

AI PC:重塑未来办公与生活方式的革命性工具

随着科技的飞速发展&#xff0c;人工智能&#xff08;AI&#xff09;已经渗透到我们生活的方方面面。而在PC领域&#xff0c;一场由AI引领的变革也正在悄然发生。从硬件到软件&#xff0c;从云端到终端&#xff0c;AI正在重塑我们的办公和生活方式。 AI工具网 | 人工智能工具推…

【蓝桥杯-单片机】基础模块:矩阵按键

文章目录 【蓝桥杯-单片机】基础模块&#xff1a;矩阵按键 【蓝桥杯-单片机】基础模块&#xff1a;矩阵按键 /** * 函数名 矩阵键盘扫描函数 * 函数功能 返回按下的按键键码值 * 入口参数 无 * 返回值 按键键码值 */ unsigned char Key_Read_Pro() {unsigned char temp 0;P3…

简单银行管理系统(C# winform SQL Server)

一、任务描述 1.使用Asp.NET技术&#xff0c;完成银行管理系统 2.开发工具&#xff1a;VS2010 3.数据库&#xff1a;SQL Server 2008 功能模块&#xff1a;登录、开户、存款、取款、转账、挂失等功能 运行界面&#xff1a; 1.登录界面&#xff08;Login.aspx&#xff09; 在…

YoloV7改进策略:卷积改进|MogaNet——高效的多阶门控聚合网络

文章目录 摘要论文:《MogaNet——高效的多阶门控聚合网络》1、简介2、相关工作2.1、视觉Transformers2.2、ViT时代的卷积网络3、从多阶博弈论交互的角度看表示瓶颈4、方法论4.1、MogaNet概述4.2、多阶门控聚合4.3、通过通道聚合进行多阶特征重新分配4.4、实现细节5、实验5.1、…

Django中的MySQL has gone away

在Django中遇到"Mysql has gone away"的错误,通常是因为MySQL数据库连接断开导致的。这可能是由于多种原因造成的,例如网络问题、数据库服务器的配置问题、数据库连接超时等。 为了解决这个问题,你可以尝试以下几个步骤: 检查数据库连接设置: 确保Django的配置文…

数据分析-Pandas两种分组箱线图比较

数据分析-Pandas两种分组箱线图比较 数据分析和处理中&#xff0c;难免会遇到各种数据&#xff0c;那么数据呈现怎样的规律呢&#xff1f;不管金融数据&#xff0c;风控数据&#xff0c;营销数据等等&#xff0c;莫不如此。如何通过图示展示数据的规律&#xff1f; 数据表&am…

牛客周赛 Round 36

赛况 C题可惜&#xff0c;比赛时模拟没有想明白&#xff0c;只对了一半&#xff0c;赛后看了大佬们的题解后恍然大悟&#xff0c;而F题是压根没思路&#xff0c;况且F题部分分也比较难拿。 题目列表 A-小红的数位删除 思路 将读入的数字整除10做三次后输出即可 参考代码 #inc…

高效管理百万级数据:MySQL备份与恢复实战指南

简介 在当今数字化时代&#xff0c;数据是企业不可或缺的核心资产之一&#xff0c;而MySQL作为一种流行的关系型数据库管理系统&#xff0c;其百万级数据的高效管理显得尤为重要。本实战指南将深入探讨MySQL备份与恢复的关键策略&#xff0c;为您提供全面而实用的解决方案。通…

streamlit学习-如何修改css样式

streamlit学习-如何修改css样式 效果图代码(srv.py)运行 streamlit默认的样式有时并不符合自己的要求。比如手机上的布局太浪费空间,我们希望一屏能放下所有的元素,本文演示了如何操作 效果图 代码(srv.py) import streamlit as st #1.31.1 import cv2 import numpy as np im…

埋点方案设计之感想

埋点方案设计是指在软件开发或者数据分析中&#xff0c;为了跟踪用户行为、收集数据以及进行分析&#xff0c;需要在代码中插入一些埋点&#xff08;Tracking&#xff09;代码&#xff0c;记录用户在应用中的各种操作和行为。下面是一个简单的埋点方案设计流程&#xff1a; 明…

报错:C51/Inc/Atmel/regx52.h(15):error41:syntax error near ‘sfr‘, expected ‘hdata‘

背景 跟着51单片机教程敲代码&#xff0c;在学习模块化编程这块&#xff0c;一会.h&#xff0c;一会.c文件的&#xff0c;文件切来切去&#xff0c;然后编译的时候就出了如题所示的错。 解决过程 看了报错信息&#xff0c;一直以为是regx52.h里的15行附近我手抖改了什么东西…

实验二(二)OSPF路由协议基础实验

1.实验介绍 1.1关于本实验 开放式最短路径优先 OSPF(Open Shortest Path First)是IETF 组织开发的一个基于链路状态的内部网关协议(Interior Gateway Protocol)。目前针对 IPv4 协议使用的是 OSPF Version 2(RFC2328);OSPF 作为基于链路状态的协议&#xff0c;OSPF 具有以下优…

OpenFeign的常规使用

架构: 一.新建module 引入依赖: <!--openfeign--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency> yml配置; server:port: 80spring:applicati…

vue3学习与使用

1.setup setup() 函数是 vue3 中&#xff0c;专门为组件提供的新属性。它为我们使用 vue3 的 Composition API 新特性提供了统一的入口&#xff0c;setup 函数会在 beforeCreate 之后&#xff0c;created 之前执行, vue3 也是取消了这两个钩子&#xff0c;统一用 setup 代替, …