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数据结构之链表相关知识总结
Jun 18 Java/Android
详解Java线程池是如何重复利用空闲线程的
Jun 26 Java/Android
spring boot项目application.properties文件存放及使用介绍
Jun 30 Java/Android
HashMap实现保存两个key相同的数据
Jun 30 Java/Android
Spring中bean的生命周期之getSingleton方法
Jun 30 Java/Android
java基础——多线程
Jul 03 Java/Android
JVM钩子函数的使用场景详解
Aug 23 Java/Android
MyBatis自定义SQL拦截器示例详解
Oct 24 Java/Android
教你在 Java 中实现 Dijkstra 最短路算法的方法
Apr 08 Java/Android
Android在Sqlite3中的应用及多线程使用数据库的建议
Apr 24 Java/Android
利用正则表达式匹配浮点型数据
May 30 Java/Android
volatile保证可见性及重排序方法
Aug 05 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函数之子字符串替换&amp;#65279; str_replace
2011/03/23 PHP
php计算两个文件相对路径的方法
2015/03/14 PHP
PHP5.2下preg_replace函数的问题
2015/05/08 PHP
php中strtotime函数性能分析
2016/11/20 PHP
JS与框架页的操作代码
2010/01/17 Javascript
修复IE9&amp;safari 的sort方法
2011/10/21 Javascript
js借助ActiveXObject实现创建文件
2013/09/29 Javascript
jquery向上向下取整适合分页查询
2014/09/06 Javascript
JS文字球状放大效果代码分享
2015/08/19 Javascript
JS+CSS实现的经典tab选项卡效果代码
2015/09/16 Javascript
javascript 闭包详解及简单实例应用
2016/12/31 Javascript
使用Vue.js 和Chart.js制作绚丽多彩的图表
2019/06/15 Javascript
微信小程序canvas分享海报功能
2019/10/31 Javascript
原生js+ajax分页组件
2020/01/30 Javascript
node.js使用 http-proxy 创建代理服务器操作示例
2020/02/10 Javascript
跟老齐学Python之用Python计算
2014/09/12 Python
python编程开发之textwrap文本样式处理技巧
2015/11/13 Python
使用PyV8在Python爬虫中执行js代码
2017/02/16 Python
如何用Python实现简单的Markdown转换器
2018/07/16 Python
pycharm 在windows上编辑代码用linux执行配置的方法
2018/10/27 Python
Python脚本利用adb进行手机控制的方法
2019/07/08 Python
Python3操作MongoDB增册改查等方法详解
2020/02/10 Python
CSS3伪类选择器:nth-child()
2009/04/02 HTML / CSS
英国知名美妆护肤在线商城:Zest Beauty
2018/04/24 全球购物
教师的实习鉴定
2013/12/15 职场文书
玩具公司的创业计划书
2013/12/31 职场文书
遗体告别仪式答谢词
2014/01/23 职场文书
大四优秀党员个人民主评议
2014/09/19 职场文书
明确岗位职责
2015/02/14 职场文书
2015年保险业务员工作总结
2015/05/27 职场文书
《跨越海峡的生命桥》教学反思
2016/02/18 职场文书
创业分两种人:那么哪些适合创业?,哪些适合不适合创业呢?
2019/08/23 职场文书
创业计划书之餐饮
2019/09/02 职场文书
如何用python插入独创性声明
2021/03/31 Python
MySQL 8.0 之不可见列的基本操作
2021/05/20 MySQL
JS实现九宫格拼图游戏
2022/06/28 Javascript