解决常用浏览器上传与下载文件中问乱码问题

解决浏览器下载与上传文件中问乱码问题

问题:
我们在写后端Servlet程序处理下载与上传问题时
我们知道下载的文件名,可以与本地文件名不同(假如你的浏览器访问的时本地资源)
如果说此时你的文件名是中文的话,还没有经过特殊处理,
此时一般就会出现乱码问题:

程序Servlet代码

public class DownLoad  extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//       1.获取下载的文件名:
         String downLoadFileName = "高楼.jpg";//我们就将其固定住了;
//       2.读取要下载的内容(通过ServletContext对象调用方法可以读取)
        ServletContext servletContext = getServletContext();
//       4.还要告诉客户端收到的数据是用来干什么的
        String mimeType = servletContext.getMimeType("/file/"+downLoadFileName);
        System.out.println("下载文件类型为:"+mimeType);
        resp.setContentType(mimeType);//告诉浏览器,下载的文件类型
        /*
         *    Content-Disposition响应头,表示收到的数据怎   么处理
         *    attachment 附件的意思,表示用来下载使用
         *    filename 表示指定下载文件名
         * */
         resp.setHeader("Content-Disposition","attachment;fileName="+downLoadFileName);
        // 5.把下载的内容传给客户端
        //斜杠被服务器解析为  http://ip:port/工程名  -----  web
        //获取资源以流的形式返回
        InputStream is = servletContext.getResourceAsStream("/file/"+downLoadFileName);
        //获取相应的输出流,因为把本地资源读取,在输出给应一个流,需要一个输出流
        OutputStream os = resp.getOutputStream();
        IOUtils.copy(is,os);
        //因为将本地相应文件读取到输入流中,然后在复制到输出流这一步的内容完全相容所以形象称其为复制
    }
}

一,IE与谷歌与新版本火狐浏览器

问题:
在这里插入图片描述
原因分析:
由于浏览器是国外设计的,在设计的时候只考虑了英文兼容问题,并没有考虑中文.

问题解决:
通过响应头,告诉浏览器,我要你以什么字符集解析我的文件名
将resp.setHeader(…)修改为
(高楼.jpg是图片的文件名,自己随意)

resp.setHeader("Content-Disposition","attachment;fileName="+ URLEncoder.encode("高楼.jpg","UTF-8"));

解决之后:
在这里插入图片描述
在这里插入图片描述

因为新版本的火狐浏览器兼容问题提升了,所以对于上面的修改,也可以解决火狐的乱码问题;

二,针对旧版本的火狐浏览器

使用BASE64编码
在这里插入图片描述

BASE64编码,简单演示:

import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;

import java.io.IOException;
import java.io.UnsupportedEncodingException;

public class BASE64编码 {

    public static void main(String[] args) throws IOException {
        /*
        *   编码操作
        *  */
        String content="BASE64编码";
        //创建一个BASE64编码器
        BASE64Encoder base64Encoder = new BASE64Encoder();
        //执行编码操作
        String enStr = base64Encoder.encode(content.getBytes("UTF-8"));
        System.out.println(enStr);//QkFTRTY057yW56CB
        /*
         *   解码操作
         *  */
        BASE64Decoder base64Decoder = new BASE64Decoder();
        byte[] bytes = base64Decoder.decodeBuffer(enStr);
        String enstr = new String(bytes,"UTF-8");
        System.out.println(enstr);//BASE64编码
    }
}

BASE64编码解决火狐乱码问题:

BASE64设置内容简单介绍(=?charset?B?xxxxxx?=):

=? ------------------------------ 表示编码内容的开始
charset ------------------------------ 表示字符集
B ------------------------------ 表示BASE64编码
xxxxx ------------------------------ 表示文件名,
?= ------------------------------ 表示编码内容的结束

这时候需要设置浏览器请求头的内容为:

resp.setHeader("Content-Disposition","attachment;fileName==?UTF-8?B?"+
                 new BASE64Encoder().encode("高楼.jpg".getBytes("UTF-8"))+"?=");

在这里插入图片描述
但是我们会发现,当我们解决好火狐以后,别的浏览器又出问题了;
因为针对不同的浏览器的解决方案不同

三,使用动态改变

思路:获取浏览器信息,使用if-else语句动态设置,编码集
我们知道,在请求头的地方会有,浏览器的信息,故我们可以获取浏览器信息进而进行判断

在这里插入图片描述

代码所示:

 if(req.getHeader("User-Agent").contains("Firefox")){
            resp.setHeader("Content-Disposition","attachment;fileName==?UTF-8?B?"+
                    new BASE64Encoder().encode("高楼.jpg".getBytes("UTF-8"))+"?=");
        }else{
            resp.setHeader("Content-Disposition","attachment;fileName="+ URLEncoder.encode("高楼.jpg","UTF-8"));
        }

---------------以上内容参照,尚硅谷JavaWep韩振国
完美解决…

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值