java文件下载的文件名乱码

//
//下载文件,并处理文件名乱码
public void downloadFile(HttpServletRequest request,HttpServletResponse response){
   String path = request.getSession().getServletContext().getRealPath("/upload/文档1.doc");
    // path是根据日志路径和文件名拼接出来的
     File file = new File(path);
    //获取日志文件名称
      String filename = file.getName();
   try {
      //判断是否是IE11
      Boolean flag= request.getHeader("User-Agent").indexOf("like Gecko")>0;
    //IE11 User-Agent字符串:Mozilla/5.0 (Windows NT 6.1; WOW64; Trident/7.0; rv:11.0) like Gecko
    //IE6~IE10版本的User-Agent字符串:Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.0; Trident/6.0)
       
       if (request.getHeader("User-Agent").toLowerCase().indexOf("msie") >0||flag){
           filename = URLEncoder.encode(filename, "UTF-8");//IE浏览器
       }else {
        //先去掉文件名称中的空格,然后转换编码格式为utf-8,保证不出现乱码,
        //这个文件名称用于浏览器的下载框中自动显示的文件名
        filename = new String(filename.replaceAll(" ", "").getBytes("UTF-8"), "ISO8859-1");
        //firefox浏览器
        //firefox浏览器User-Agent字符串: 
        //Mozilla/5.0 (Windows NT 6.1; WOW64; rv:36.0) Gecko/20100101 Firefox/36.0
       }
    InputStream fis = new BufferedInputStream(new FileInputStream(path));
       byte[] buffer;
    buffer = new byte[fis.available()];
       fis.read(buffer);
       fis.close();
       response.reset();
       response.addHeader("Content-Disposition", "attachment;filename=" +filename);
       response.addHeader("Content-Length", "" + file.length());
       OutputStream os = response.getOutputStream();
       response.setContentType("application/octet-stream");
       os.write(buffer);// 输出文件
       os.flush();
       os.close();
   } catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
  }
时间: 2024-08-28 20:45:45

java文件下载的文件名乱码的相关文章

asp.net 文件下载 解决文件名乱码

using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.IO; using ElementLibrary.BLL; using ElementLibrary.MODEL; using System.Text; /* * LiuH * Descr:下载处理DownLoadFile.ashx * Addtime:2014/8/26 * LastModifyTim

文件下载中文文件名乱码

B/S应用中,下载一个附件保存时,中文文件名会乱码,在实际开发中经常遇到,现贴出C#和JAVA的解决方法: C#: Response.AppendHeader("Content-Disposition", "attachment;filename=" + Tools.toUtf8String(result)); 其中用到的转换方法: public static string ToUtf8String(String s) { StringBuilder sb = ne

java 文件下载文件名称乱码

乱码的原因是什么?每个浏览器的编码不一样,火狐采用的是base64.ie和谷歌采用的是url编码 所以我们在设置响应头的时候Content-Type getServletContext().getMineType(filename);Content-Disposition accachment;filename=编码后的filename url编码name = URLEncoder.encode(filename, "UTF-8"); base64编码/** 传入文件的名称,进行Bas

文件下载之文件名乱码问题的工具类

package cn.itcast.down.utils; import java.io.IOException;import java.net.URLEncoder; import javax.servlet.http.HttpServletRequest; import sun.misc.BASE64Encoder;/* * 下载文件的工具类 */public class DownUtils { public static String filenameEncoding(String fil

关于java文件下载文件名乱码问题解决方案

关于java文件下载文件名乱码问题解决方案 做为一名程序员,大家应该都遇到过乱码的问题吧!这篇文章是自己解决关于关于java文件下载文件名乱码问题的处理: String fileName = "下载的文件名"; String userAgent = request.getHeader("User-Agent"); //针对IE或者以IE为内核的浏览器: if (userAgent.contains("MSIE")||userAgent.conta

Java文件下载文件名乱码

文件下载文件名乱码主要是没有对文件名进行编码,这里适用的浏览器主要包括(IE,火狐,谷歌,360) 代码如下 //火狐浏览器 if(ServletActionContext.getRequest().getHeader("USER-AGENT").toLowerCase().indexOf("firefox") >0){ return new String(文件名.getBytes(), Const.CHARSET_ISO8859_1); } //其他浏览器

Struts2 .apk 文件下载及解决中文文件名乱码问题(转)

1.Tomcat服务器不能下载 .apk类型文件 Android的APK安装包不能下载或下载文件是以 .zip为后缀名而不是 .apk为文件后缀名时,需在 Tomcat 的 web.xml 配置文件中加入以下 MIME 类型: 1 <mime-mapping> 2 <extension>apk</extension> 3 <mime-type>application/vnd.android.package-archive</mime-type>

Java Web文件下载1——文件下载实现和乱码处理

文件上传和下载是web开发中常遇到的问题,这几天在做一个项目又用到了文件下载,之前也零零散散记了些笔记,今天来做一下整理.文件上传还有待进一步测试,这里先说一下文件下载. 一.文件下载处理流程 文件下载处理流程其实很清晰,即: 1.根据文件名或者文件路径定位文件,具体的策略主要根据自己的需求,总之需要系统能找到的文件全路径. 2.获取输入流,从目标文件获取输入流. 3.获取输出流,从response中获取输出流. 4.从输入流读入文件,通过输出流输出文件.这是真正的下载执行过程. 5.关闭IO流

文件下载文件名乱码解决

if(request.getHeader("User-Agent").toUpperCase().indexOf("MSIE") > 0){ response.setHeader("Content-disposition", "attachment; filename=" + URLEncoder.encode(product.getRealName1(), "UTF-8")); }else{ res