Spring MVC文件下载配置


版权声明


文件下载

在Spring MVC中通常利用commons-io实现文件下载,示例代码如下:

java 复制代码
@Controller
@RequestMapping("......")
public class DownloadController {
    @RequestMapping("/download")
    public ResponseEntity<byte[]> downloadFile(HttpServletRequest request,
           @RequestParam("fileName") String fileName) throws Exception {
        
        // 省略非核心代码
      
        // 设置响应头
        HttpHeaders headers = new HttpHeaders();
        // 通知浏览器以下载的方式打开文件
        headers.setContentDispositionFormData("attachment", downloadName);
        // 通知浏览器以流的形式下载文件
        headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);
        // 将文件对象转换为字节数组
        byte[] byteArray = FileUtils.readFileToByteArray(file);
        // 状态码
        HttpStatus httpStatus = HttpStatus.OK;
        // 创建响应实体
        ResponseEntity<byte[]> responseEntity
        = new ResponseEntity<>(byteArray, headers, httpStatus);
        // 返回响应实体
        return responseEntity;
    }

}

示例分析

在Web应用中,文件下载通常意味着服务器需要将文件的内容发送给客户端。由于文件可能包含任何类型的数据(文本、图片、音频、视频等),因此最通用的方式是将文件内容视为二进制数据(即字节)进行传输。

在Java中,字节数组(byte[])是用来存储二进制数据的基本结构。当想要读取文件内容并通过HTTP响应发送时,将文件内容读取为字节数组是最直接的方法。如此便可以将这个字节数组作为响应体发送给请求的客户端。

ResponseEntity类允许你直接设置这个字节数组作为响应体。通过其构造器或构建器模式,可以很容易地创建一个包含字节数组、HTTP状态码和HTTP响应头的ResponseEntity对象。

在Spring MVC中ResponseEntity是一种特殊的返回类型,它提供了对HTTP响应的完全控制。当控制器方法返回一个ResponseEntity对象时,Spring MVC框架会识别这个对象,并将其自动转换为符合HTTP协议的响应消息。这包括设置HTTP状态码、响应头和响应体。使用ResponseEntity的好处是开发者不需要直接与底层的HttpServletResponse对象交互。相反,他们可以使用ResponseEntity的高级抽象来创建和定制HTTP响应。这使得代码更加简洁、易读和易于维护。

相关推荐
Devin~Y16 小时前
互联网大厂Java面试:Spring Boot/Redis/Kafka/K8s 可观测 + RAG(向量检索/Agent)三轮追问实录
java·spring boot·redis·kafka·kubernetes·spring mvc·webflux
bingyan03718 天前
openclaw-技能skills配置入门
配置·技能·skill·openclaw
HelloTonyGo12 天前
个人游戏笔记本免费“养龙虾”(七)OpenClaw的openclaw.json文件的基本配置
ubuntu·json·配置·读写权限·openclaw
Irene199117 天前
Vue3+Pinia+TypeScript 前端开发环境,CLAUDE.md 文件应该怎么写
claude·配置
特立独行的猫a20 天前
OpenHarmony海思WS63星闪平台:使用Mongoose 网路库文件下载封装与断点续传实现
openharmony·mongoose·海思·文件下载·ws63
oscar99921 天前
探秘Claude Code的“.claude”目录:那些藏在背后的配置与记忆
memory·配置·rule·claude code·sikil
HelloTonyGo23 天前
个人游戏笔记本免费“养龙虾”(三)OpenClaw的安全配置指南
ubuntu·网络安全·配置·读写权限·openclaw
七夜zippoe24 天前
OpenClaw 接入飞书:完整配置指南
人工智能·microsoft·飞书·配置·openclaw
疯狂吧小飞牛25 天前
daemon.json–docker常用配置
docker·配置
七夜zippoe1 个月前
OpenClaw 配置文件全解析:openclaw.yaml 详解
配置·yaml·openclaw