Java生成文件放入json传至前端下载(以Excel为例)

功能说明

  • 页面原来存在查询功能,现新增下载功能,将查询出来的数据导出至Excel表格
  • 数据传输格式为json

解决方案

  1. 前端发起下载请求
  2. 后台根据查询条件先查询出数据
  3. 后台将数据生成Excel表格
  4. 将Excel表格转为base64字符串,放入json,传给前端
  5. 前端获取json中的文件字符串,开启下载

关键代码

前端请求及返回处理

导出按钮

<el-button type="success" icon="el-icon-download" @click="downloaddata">导出</el-button>

开启下载方法

methods: {
   
  downloaddata() {
   
    // axios发起请求
    this.$axios({
   
      method: 'post',
      url: '/xxx',
      data: {
   
        "age": this.UserAge,
        ...
      }
    }).then((res) => {
   
      // 将base64格式文件转为blob供下载
      function dataURLtoBlob(base64Str) {
   
        var bstr = atob(base64Str), n = bstr.length, u8arr = new Uint8Array(n);
        while (n--) {
   
          u8arr[n] = bstr.charCodeAt(n);
        }
        // 这里设置的是excel格式的文件,其他格式见后文
        return new Blob([u8arr], {
    type: "application/vnd.ms-excel" });
      }
  
      const blob = dataURLtoBlob(res.data.base64file) // 入参为json中的base64编码文件
      const url = window.URL.createObjectURL(blob);
      
      // 开启下载任务
  	  const link 
阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Java生成下载JSON文件的过程相对简单。以下是一个基本的示例代码,可以实现这个功能: ```java import java.io.BufferedWriter; import java.io.FileWriter; import java.io.IOException; import java.io.PrintWriter; import com.google.gson.Gson; public class JsonGenerator { public static void main(String[] args) { // 创建一个对象并设置数据 MyData myData = new MyData(); myData.setName("John"); myData.setAge(25); myData.setCity("New York"); // 将对象转换为JSON字符串 Gson gson = new Gson(); String jsonString = gson.toJson(myData); // 生成JSON文件 String filePath = "path/to/your/file.json"; try { PrintWriter writer = new PrintWriter(new BufferedWriter(new FileWriter(filePath))); writer.println(jsonString); writer.close(); System.out.println("JSON文件生成:" + filePath); } catch (IOException e) { e.printStackTrace(); } } } class MyData { private String name; private int age; private String city; // 省略构造函数和getter/setter方法 // 注意:为了将对象转换为JSON字符串,MyData类必须提供无参数构造函数。 MyData() {} } ``` 这段代码做了以下几件事情: 1. 创建一个`MyData`对象并设置数据。 2. 使用Gson库将该对象转换为JSON字符串。 3. 使用`BufferedWriter`和`PrintWriter`将JSON字符串写入文件。 4. 通过指定文件路径生成JSON文件。 5. 如果一切顺利,将输出文件路径。 要使用此代码,请确保在项目中添加了Gson库的依赖。 通过这段代码,你可以生成JSON文件并将其下载到用户的计算机上。但是要注意,下载的过程通常是Web应用程序的一部分,需要使用合适的HTTP响应头和Servlet API进行处理。以上代码只是生成并保存JSON文件到本地的示例,你可能需要根据实际情况进行适当的修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

每天码到十二点

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值