码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • springboot + vue实现数据导出


    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

    文章目录

    • 前言
    • 一、需求
    • 二、Springboot进行数据导出
      • 1.Java后端代码
      • 2.Vue前端代码
      • 3.其他几种Java后端导出方法
        • 1、使用BufferedOutputStream,一次性写入
        • 2、不使用BufferedOutputStream,循环写入
    • 总结


    前言

    这两天在项目中使用到Java的导入导出功能,以前对这块有一定了解,但是没有系统学习过,今天在这里进行记录,方便以后查阅。


    一、需求

    项目的需求是将项目中的JSON实体数据导出为.json文件,导出的文件,可以作为元数据导入进行实体初始化。项目不是使用普通的springboot框架(普通的springboot框架很容易完成),因此走了一些弯路,在这篇文章中,将先讲解使用springboot框架进行导出,然后再讲解非springboot框架的导出。

    二、Springboot进行数据导出

    1.Java后端代码

    @RequestMapping("/download")
    public void download(String path, HttpServletResponse response) {
    	// 固定写法
    	response.setContentType("application/OCTET-STREAM;charset=UTF-8");
    	response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(filename, "UTF-8"));
    	File file = new File(path);
    	try {
    	    InputStream fis = new FileInputStream(file);
    	    OutputStream out = new BufferedOutputStream(response.getOutputStream());
    	    byte[] buffer = new byte[1024];
    	    int len;
    	    while ((len = fis.read(buffer)) != -1) {
    	        out.write(buffer, 0, len);
    	        out.flush();
    	    }
    	} catch (Exception e) {
    		throw new RuntimeException(e);
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    导出操作时,返回值类型必须为void,由于项目有指定的返回格式(返回值类型不能为void),导致类型不匹配报错,在新写了处理方法之后,解决了这个问题。 这里使用了BufferedOutputStream,能加快导出速度。不用BufferedOutputStream,只使用response.getOutputStream()也是可以的。此外,这里使用了循环写入输出流中,而不是一次写入。

    2.Vue前端代码

        handleExport(row) {
          const id = row.id || this.ids
          const name = row.name || this.names[0]
          const code = row.code || this.codes
          const params = {
            exportCodes: JSON.stringify(code)
          }
          this.download('/Thingmax/Things/Export',  params,  name + '.json')
        },
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    download方法第一个参数是导出方法的响应路由,第二个参数为导出时携带的参数,第三个参数为导出的文件名称。

    3.其他几种Java后端导出方法

    1、使用BufferedOutputStream,一次性写入

    exportEntities.put("Entities", entities);
    String content = exportEntities.toJSONString();
    try {
    	BufferedOutputStream out = new BufferedOutputStream(response.getOutputStream());
    	out.write(content.getBytes(StandardCharsets.UTF_8));
    	out.flush();
    	out.close();
    } catch (Exception e) {
         throw new RuntimeException(e);
     }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    一次性将数据读取到内存,通过响应输出流输出到前端

    2、不使用BufferedOutputStream,循环写入

    InputStream inputStream = new FileInputStream(path);
    ServletOutputStream outputStream = response.getOutputStream();
       byte[] b = new byte[1024];
       int len;
       //从输入流中读取一定数量的字节,并将其存储在缓冲区字节数组中,读到末尾返回-1
       while ((len = inputStream.read(b)) > 0) {
           outputStream.write(b, 0, len);
       }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    总结

    本篇文章对Java的导出进行了记录。

  • 相关阅读:
    QT配置FFmpeg出现错误原因
    图论17(Leetcode864.获取所有钥匙的最短路径)
    lazada按关键字搜索商品 API 返回值说明
    python基于PHP+MySQL的健身俱乐部网站的设计与实现
    Codeforces Round 826 (Div. 3) D 遍历暴力求解
    【hive】行转列—explode()/posexplode()/lateral view 函数使用场景
    消防应急照明和疏散指示系统在城市隧道中的应用
    IPWorks Zip Delphi 流式压缩组件
    面试经典 150 题 2 —(双指针)— 392. 判断子序列
    故障诊断实验台 | PT500mini轴承齿轮箱转子故障实验台
  • 原文地址:https://blog.csdn.net/qq_43403676/article/details/126923857
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号