文件下载:"Content-disposition","attachment; filename=中文名>>>解决方案

文件下载时常会出现如下问题: response.setHeader("Content-disposition","attachment; filename="+as+"");
如果as直接写中文名字时,就会直接在IE页面打开Excel文件(弹出后点打开会在IE页面打开,注意此时的“你想打开或保存此文件吗?”,名称会显示一个类似CAK....的名称,实现上并不是正常的 *.xls格式的名称),如图所示:

而不是另外弹出并打开Excel文件。解决办法是:(程序片段)

        String as="我明白了.xls";
        String fileName =as;// = java.net.URLEncoder.encode(as, "UTF-8");
        /*根据request的locale 得出可能的编码,中文操作系统通常是gb2312*/
            fileName = new String(as.getBytes("GB2312"), "ISO_8859_1");  
            as=fileName;
        response.setContentType("application/vnd.ms-excel");
        response.setHeader("Content-disposition","attachment; filename="+as+"");   
     
        BufferedInputStream bis = null;
     BufferedOutputStream bos = null;
     try {
        // bis = new BufferedInputStream(new FileInputStream(getServletContext().getRealPath("" + filename)));
      bis = new BufferedInputStream(new FileInputStream(dirFile));
      bos = new BufferedOutputStream(response.getOutputStream());

         byte[] buff = new byte[2048];
         int bytesRead;

         while(-1 != (bytesRead = bis.read(buff, 0, buff.length))) {
             bos.write(buff,0,bytesRead);
         }
     } catch(final IOException e) {
         System.out.println ( "出现IOException." + e );
     } finally {
         if (bis != null)
             bis.close();
         if (bos != null)
             bos.close();
     }

程序段中最关键的一句:

new String(as.getBytes("GB2312"), "ISO_8859_1");  

将文件命名转码. OK结果正常了>>>



这样就可以下载时用中文名称了,并且是另外打开Excel文件的。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值