Spring Boot实现文件上传下载


Posted in Java/Android onAugust 14, 2022

本文实例为大家分享了Spring Boot实现文件上传下载的具体代码,供大家参考,具体内容如下

示例【Spring Boot  文件上传下载】

程序清单:/springboot2/src/main/resources/templates/register.html

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>注册</title>
<link rel="stylesheet" th:href="@{css/bootstrap.min.css}" >
<link rel="stylesheet" th:href="@{css/bootstrap-theme.min.css}" />
<script type="text/javascript" th:src="@{js/jquery-1.11.0.min.js}"></script>
<script type="text/javascript" th:src="@{js/bootstrap.min.js}"></script>
</head>
<body>
    <div class="panel panel-primary">
        <div class="panel-heading">
            <h3 class="panel-title">Spring Boot文件上传</h3>
        </div>
    </div>
    <div class="container">
        <div class="row">
            <div class="col-md-8">
                <form action="upload" method="post" enctype="multipart/form-data">
                    <div class="form-group">
                        <div class="input-group col-md-4">
                            <span class="input-group-addon">
                                <i class="glyphicon glyphicon-user"></i>
                            </span>
                            <input class="form-control" type="text" name="userName">
                        </div>
                    </div>
                    <div class="form-group">
                        <div class="input-group col-md-4">
                            <span class="input-group-addon">
                                <i class="glyphicon glyphicon-search"></i>
                            </span>
                            <input class="form-control" type="file" name="head">
                        </div>
                    </div>
                    <div class="form-group">
                        <div class="col-md-4">
                            <button type="submit" class="btn btn-success">注册</button>
                        </div>
                    </div>
                </form>
            </div>
        </div>
    </div>
</body>
</html>

程序清单:/springboot2/src/main/resources/templates/userInfo.html

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>用户信息</title>
<link rel="stylesheet" th:href="@{css/bootstrap.min.css}" >
<link rel="stylesheet" th:href="@{css/bootstrap-theme.min.css}" />
<script type="text/javascript" th:src="@{js/jquery-1.11.0.min.js}"></script>
<script type="text/javascript" th:src="@{js/bootstrap.min.js}"></script>
</head>
<body>
    <div class="panel panel-primary">
        <div class="panel-heading">
            <h3 class="panel-title">Spring Boot文件下载</h3>
        </div>
    </div>
    <div class="container">
        <div class="panel panel-primary">
            <div class="panel-heading">
                <h3 class="panel-title">用户信息列表</h3>
            </div>
        </div>
        <div class="panel-body">
            <div class="table table-responsive">
                <table class="table table-bordered" id="userTable">
                    <tbody class="text-center">
                        <tr>
                            <td><img th:src="@{'upload/'+${user.head.originalFilename}}" height="30"></td>
                            <td th:text="${user.userName}">用户名</td>
                            <td><a th:href="@{download(filename=${user.head.originalFilename })}" >下载</a></td>
                        </tr>
                    </tbody>
                </table>
            </div>
        </div>
    </div>
</body>
</html>

程序清单:/springboot2/src/main/java/com/dwx/hello/User.java

package com.dwx.hello;
import org.springframework.web.multipart.MultipartFile;
public class User {
    private String userName;
    private MultipartFile head;
    public String getUserName() {
        return userName;
    }
    public void setUserName(String userName) {
        this.userName = userName;
    }
    public MultipartFile getHead() {
        return head;
    }
    public void setHead(MultipartFile head) {
        this.head = head;
    }
}

程序清单:/springboot2/src/main/java/com/dwx/hello/UserController.java

package com.dwx.hello;
import java.io.File;
import java.io.IOException;
import java.net.URLEncoder;
import javax.servlet.http.HttpServletRequest;
import org.apache.commons.io.FileUtils;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.http.ResponseEntity.BodyBuilder;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestHeader;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
@Controller
public class UserController {
    @RequestMapping("/registerForm")
    public String registerForm() {
        return "register";
    }
    @RequestMapping("/upload")
    public String upload(HttpServletRequest request,
            @ModelAttribute User user,Model model) throws IllegalStateException, IOException {
        if(!user.getHead().isEmpty()) {
            String path=request.getServletContext().getRealPath("/upload");
            String fileName=user.getHead().getOriginalFilename();
            File filePath=new File(path,fileName);
            if(!filePath.getParentFile().exists()) {
                filePath.getParentFile().mkdirs();
            }
            user.getHead().transferTo(new File(path+File.separator+fileName));
            model.addAttribute("user", user);
            return "userInfo";
        }else {
            return "error";
        }
    }
    @RequestMapping(value="/download")
     public ResponseEntity<byte[]> download(HttpServletRequest request,
             @RequestParam("filename") String filename,
             @RequestHeader("User-Agent") String userAgent,
             Model model)throws Exception{
        // 下载文件路径
        String path = request.getServletContext().getRealPath(
               "/upload/");
        // 构建File
        File file = new File(path+File.separator+ filename);
        // ok表示Http协议中的状态 200
       BodyBuilder builder = ResponseEntity.ok();
       // 内容长度
       builder.contentLength(file.length());
       // application/octet-stream : 二进制流数据(最常见的文件下载)。
       builder.contentType(MediaType.APPLICATION_OCTET_STREAM);
       // 使用URLDecoder.decode对文件名进行解码
       filename = URLEncoder.encode(filename, "UTF-8");
       // 设置实际的响应文件名,告诉浏览器文件要用于【下载】、【保存】attachment 以附件形式
       // 不同的浏览器,处理方式不同,要根据浏览器版本进行区别判断
       if (userAgent.indexOf("MSIE") > 0) {
               // 如果是IE,只需要用UTF-8字符集进行URL编码即可
               builder.header("Content-Disposition", "attachment; filename=" + filename);
       } else {
               // 而FireFox、Chrome等浏览器,则需要说明编码的字符集
               // 注意filename后面有个*号,在UTF-8后面有两个单引号!
               builder.header("Content-Disposition", "attachment; filename*=UTF-8''" + filename);
       }
       return builder.body(FileUtils.readFileToByteArray(file));
     }
}

运行Spring Boot项目,访问以下地址:http://localhost:8080/registerForm

Spring Boot实现文件上传下载

Spring Boot实现文件上传下载

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Java/Android 相关文章推荐
Java基础之详解HashSet的使用方法
Jun 30 Java/Android
JavaWeb Servlet实现网页登录功能
Jul 04 Java/Android
Java实现聊天机器人完善版
Jul 04 Java/Android
Spring Boot 整合 Apache Dubbo的示例代码
Jul 04 Java/Android
Java获取e.printStackTrace()打印的信息方式
Aug 07 Java/Android
Java中CyclicBarrier和CountDownLatch的用法与区别
Aug 23 Java/Android
使用jpa之动态插入与修改(重写save)
Nov 23 Java/Android
关于@OnetoMany关系映射的排序问题,使用注解@OrderBy
Dec 06 Java/Android
关于MybatisPlus配置双数据库驱动连接数据库问题
Jan 22 Java/Android
解决persistence.xml配置文件修改存放路径的问题
Feb 24 Java/Android
解析探秘fescar分布式事务实现原理
Feb 28 Java/Android
Java9新特性对HTTP2协议支持与非阻塞HTTP API
Mar 16 Java/Android
Springboot集成kafka高级应用实战分享
spring boot实现文件上传
Aug 14 #Java/Android
Java使用HttpClient实现文件下载
Aug 14 #Java/Android
HttpClient实现表单提交上传文件
Aug 14 #Java/Android
HttpClient实现文件上传功能
Aug 14 #Java/Android
SpringBoot Http远程调用的方法
Aug 14 #Java/Android
基于Android10渲染Surface的创建过程
Aug 14 #Java/Android
You might like
php 攻击方法之谈php+mysql注射语句构造
2009/10/30 PHP
PHP判断数组是否为空的常用方法(五种方法)
2017/02/08 PHP
PHP session垃圾回收机制实例分析
2019/06/28 PHP
javascript实现获取浏览器版本、操作系统类型
2015/01/29 Javascript
JS简单实现城市二级联动选择插件的方法
2015/08/19 Javascript
jQuery禁用快捷键例如禁用F5刷新 禁用右键菜单等的简单实现
2016/08/31 Javascript
jQuery Easyui datagrid行内实现【添加】、【编辑】、【上移】、【下移】
2016/12/19 Javascript
js使用Replace结合正则替换重复出现的字符串功能示例
2016/12/27 Javascript
Spring Boot+AngularJS+BootStrap实现进度条示例代码
2017/03/02 Javascript
使用vue和datatables进行表格的服务器端分页实例代码
2017/06/07 Javascript
Node.js中Bootstrap-table的两种分页的实现方法
2017/09/18 Javascript
vue.js 中使用(...)运算符报错的解决方法
2018/08/09 Javascript
JavaScript数据结构之栈实例用法
2019/01/18 Javascript
ES6入门教程之let、const的使用方法
2019/04/13 Javascript
js中的this的指向问题详解
2019/08/29 Javascript
解决vue初始化项目时,一直卡在Project description上的问题
2019/10/31 Javascript
手把手教您实现react异步加载高阶组件
2020/04/07 Javascript
uniapp微信小程序实现一个页面多个倒计时
2020/11/01 Javascript
[01:32]DOTA2上海特锦赛现场采访:最想COS的英雄
2016/03/25 DOTA
[36:05]完美世界DOTA2联赛循环赛 Forest vs DM 第一场 11.06
2020/11/06 DOTA
利用pyinstaller打包exe文件的基本教程
2019/05/02 Python
用Q-learning算法实现自动走迷宫机器人的方法示例
2019/06/03 Python
python实现合并多个list及合并多个django QuerySet的方法示例
2019/06/11 Python
Python3.8对可迭代解包的改进及用法详解
2019/10/15 Python
python thrift 实现 单端口多服务的过程
2020/06/08 Python
Python控制台实现交互式环境执行
2020/06/09 Python
野兽派官方旗舰店:THE BEAST 野兽派
2016/08/05 全球购物
10条PHP编程习惯
2014/05/26 面试题
教师远程培训感言
2014/03/06 职场文书
施工员岗位职责
2014/03/16 职场文书
租房协议书
2014/04/10 职场文书
后备干部培训方案
2014/05/22 职场文书
咖啡店创业计划书范文
2014/09/15 职场文书
2019年冬至:天冷暖人心的问候祝福语大全
2019/12/20 职场文书
如何用PHP实现分布算法之一致性哈希算法
2021/05/26 PHP
基于Java的MathML转图片的方法(示例代码)
2021/06/23 Java/Android