实现下载文件的前后台写法

在这里插入图片描述
这里写的是前台vue+Springboot项目,原理一样。
话不多说上代码

后台
Controller层

/**********************************
     * 用途说明: 下载信息模版(Poi方式)
     * 参数说明 null
     * 返回值说明: void
     ***********************************/
    @GetMapping("downLoadFile")
    public void downLoadFile(String fileName) {
        try {
            //读取resource文件夹下的导入模板
            String path = this.getClass().getClassLoader().getResource("").getPath();
            try{
                downloadFile(path,fileName);
            }catch (Exception e){
                e.printStackTrace();
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

Service层

/**********************************
    * 用途说明: Poi下载模版调用
    * 参数说明 path
    * 参数说明 fileName
    * 返回值说明: void
    ***********************************/
    public static void downloadFile(String path, String fileName) throws Exception{
        //读取resource文件夹下的导入模板(根据个人项目放置位置)
        File file = new File(path + "fileTemplate" + File.separator + fileName);
        String fileCnName = "";
        if("aaa.xlsx".equals(fileName)){
            fileCnName = "AAA信息导入模板.xlsx";
        }else if("".equals(fileCnName)){
            fileCnName = fileName;
        }
        InputStream inputStream = null;
        try {
            inputStream = new FileInputStream(file);
            HttpServletResponse response = HttpServlet.getResponse();
            OutputStream outputStream = response.getOutputStream();
            byte[] buff = new byte[2048];
            //设置响应头
            response.setCharacterEncoding("UTF-8");
            response.setContentType("application/x-msdownload;charset=utf-8");
            response.setHeader("Content-disposition", "attachment;filename=" + URLEncoder.encode(fileCnName, "UTF-8"));
            int num = -1;
            while ((num = inputStream.read(buff)) != -1) {
                outputStream.write(buff, 0, num);
            }
            response.flushBuffer();
            outputStream.flush();
            outputStream.close();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            inputStream.close();
        }
    }

VUE就很简单了 我们用的是window.open 可以用别的方式
ip我写的是我本地的ip,具体怎么访问但是修改,或者陪在配置文件中都可以

//下载模板
    downloadTemplate: function () {      let params = "aaa.xlsx"      window.open("http://localhost:8080/downLoad/downLoadFile?fileName=" + params, "_blank");    },

说到window.open了,那就大概介绍下

open() 方法用于打开一个新的浏览器窗口或查找一个已命名的窗口

window.open(URL,name,specs,replace)

  1. URL 可选。打开指定的页面的URL。如果没有指定URL,打开一个新的空白窗口
  2. name 可选。指定target属性或窗口的名称。支持以下值:
    _blank - URL加载到一个新的窗口。这是默认_parent - URL加载到父框架_self - URL替换当前页面_top - URL替换任何可加载的框架集name - 窗口名称
  3. specs 可选。一个逗号分隔的项目列表。支持以下值:
    channelmode=yes|no|1|0 是否要在影院模式显示 window。默认是没有的。仅限IE浏览器
    directories=yes|no|1|0 是否添加目录按钮。默认是肯定的。仅限IE浏览器
    fullscreen=yes|no|1|0 浏览器是否显示全屏模式。默认是没有的。在全屏模式下的 window,还必须在影院模式。仅限IE浏览器
    height=pixels 窗口的高度。最小.值为100
    left=pixels 该窗口的左侧位置
    location=yes|no|1|0 是否显示地址字段.默认值是yes
    menubar=yes|no|1|0 是否显示菜单栏.默认值是yes
    resizable=yes|no|1|0 是否可调整窗口大小.默认值是yes
    scrollbars=yes|no|1|0 是否显示滚动条.默认值是yes
    status=yes|no|1|0 是否要添加一个状态栏.默认值是yes
    titlebar=yes|no|1|0 是否显示标题栏.被忽略,除非调用HTML应用程序或一个值得信赖的对话框.默认值是yes
    toolbar=yes|no|1|0 是否显示浏览器工具栏.默认值是yes
    top=pixels 窗口顶部的位置.仅限IE浏览器
    width=pixels 窗口的宽度.最小.值为100
  4. replace Optional.Specifies规定了装载到窗口的 URL 是在窗口的浏览历史中创建一个新条目,还是替换浏览历史中的当前条目。支持下面的值:
    true - URL 替换浏览历史中的当前条目。
    false - URL 在浏览历史中创建新的条目。
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值