Java 下载Excel打不开是什么鬼

场景:草草写了一个独立的文件服务,可以支持文件的上传和下载操作(常规操作),操作图片的读取mei有问题,但是在下载Excel文件之后,发现提示文件损坏,无法正常打开。

排查:直接从文件服务器上将文件拷贝出来,发现文件能正常打开没有问题。

分析:下载excel在服务器上后缀名称为.xls;但下载下来为.xlsx

观察:文件下载有问题-在代码中没有设置下载文件的contentType和Head

         ----Content-Type:       application/octet-stream  

             这里有content-type的对应标识:https://blog.csdn.net/luman1991/article/details/53423305

             该实体头的作用是让服务器告诉浏览器它发送的数据属于什么文件类型
         ----Content-Disposition: attachment;filename=aaa.zip 

             当Content-Type 的类型为要下载的类型时 , 这个扩展头会告诉浏览器这个文件的名字和类型。

            Content-Disposition中指定的类型是文件的扩展名,并且弹出的下载对话框中的文件类型图片是按照文件的扩展名显示的,点保存后,文件以filename的值命名,保存类型以Content中设置的为准。
注意:在设置Content-Disposition头字段之前,一定要设置Content-Type头字段。(这里摘自博文,自己测试无论位置前后,都能正常下载打开。)

解决:下载文件时设置消息头Content-Type和扩展头Content-Disposition

            java在1.7之后提供了判定下载文件contentType的方法:

            可以自动检测文件类型,

            Path path = Paths.get(filePath);
            contenType = Files.probeContentType(path);
            System.out.println(contenType);
            response.setContentType(contenType);

            另外,对未知的的文件类型,可以使用

response.setContentType("application/octet-stream;charset=utf-8");

 对Content-Disposition的设置主要根据服务器上带后缀的文件的名称,我这里需求是要跟服务器上文件类型及后缀名称保持一致,所以直接在扩展头写入写入的是全文件名称。

response.setHeader("Content-Disposition", "attachment;fileName=" + path.getFileName());

--over--

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值