zoukankan      html  css  js  c++  java
  • 文件下载 解决中文文件名乱码

    在写文件下载的时候遇到的一个问题,也就是下载的文件的文件名是中文的话,浏览器下载的时候可能是乱码,解决方案如下:

    因为从服务器向浏览器发送中文时,需要对内容进行URL编码。
    > 大部分浏览器使用如下方式即可解决乱码问题:URLEncoder.encode(fileName, "utf-8");
    > 但是火狐默认以Base64来解码的,所以要为火狐单独处理。
    > 可以使用如下代码来判断浏览器的类型,然后进行不同的编码处理
     // 请求客户端操作系统的信息  
    	    final String userAgent = request.getHeader("USER-AGENT");  
    	    if(userAgent.contains("Firefox")){
    			//是火狐浏览器,使用BASE64编码
    			fileName = "=?utf-8?b?"+new BASE64Encoder().encode(fileName.getBytes("utf-8"))+"?=";
    		}else{
    			//给文件名进行URL编码
    			//URLEncoder.encode()需要两个参数,第一个参数时要编码的字符串,第二个是编码所采用的字符集
    			fileName = URLEncoder.encode(fileName, "utf-8");
    		}
    

    然后再去设置响应头,应该就没问题了

     response.setContentType(servletContext.getMimeType(fileName));
    response.addHeader("Content-Disposition", "attachment; filename=" + fileName);  
    		 
    
    二、还有一种通用的方法,可能简单点,但是如果文件名夹杂个别特殊符号,可能还会乱码,不过对大多数带有特殊符号的中文名还是好使的;
    - 向将字符串用gbk进行解码,然后在使用iso8859-1进行编码
    fileName = new String(fileName.getBytes("gbk"),"iso8859-1");
  • 相关阅读:
    linux安装skype
    (转)程序员最应该读的图书
    Smarty 学习笔记六 缓存
    Smarty 学习笔记二 常用内置变量
    Smarty 学习笔记七 debug
    文本文件与二进制文件区别
    zz 通用线程:Awk 实例,第 2部分
    MIT墙上的格言
    AWK学习笔记
    zz SED单行脚本快速参考 以及 AWK版本
  • 原文地址:https://www.cnblogs.com/Actexpler-S/p/7401799.html
Copyright © 2011-2022 走看看