使用response下载没反应

        response.reset();
        File excelFile = new File(filePath);
        // 1.设置文件ContentType类型,这样设置,会自动判断下载文件类型
        response.setContentType("application/octet-stream");
        // 2.设置文件头:处理文件名编码,防止不同浏览器中文的文件名出现乱码
        String headerValue = "attachment;";
        String fileName = "体验馆报名名单.xlsx";
        headerValue += " filename=\"" + fileOperationService.encodeURIComponent(fileName) + "\";";
        headerValue += " filename*=utf-8''" + fileOperationService.encodeURIComponent(fileName);
        response.setHeader("Content-Disposition", headerValue);
        response.addHeader("Content-Length", String.valueOf(excelFile.length()));
        
        // 通过文件流下载
        try {
            InputStream ins = new BufferedInputStream(new FileInputStream(excelFile));
            byte[] buffer = new byte[ins.available()];
            ins.read(buffer);
            ins.close();
            OutputStream ous = new BufferedOutputStream(response.getOutputStream());
            ous.write(buffer);
            ous.flush();
            ous.close();
        } catch (IOException e) {
            e.printStackTrace();

        }



ajax请求只是个“字符型”的请求,即请求的内容是以文本类型存放的。文件的下载是以二进制形式进行的,虽然可以读取到返回的response,但只是读取而已,是无法执行的。 

解决方案,不用ajax:

window.location.href=_contextPath + "/signUp/exportSignUpList.do";


  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值