HttpServletResponse下载文件(中文名称下载)-------手动编码实现下载

这篇博客详细介绍了如何使用HttpServletResponse手动编码实现文件下载功能,特别关注了中文文件名的问题。通过示例代码展示了DownloadServlet的实现,以及Base64Util在处理文件过程中的应用。同时,配置了web.xml并提供了download.html的示例。博主提到在谷歌和火狐浏览器下测试正常,但遇到了使用ISO-8859-1编码时的控制台报错问题,期待解决方案。
摘要由CSDN通过智能技术生成

DownloadServlet:
 

package com.yuming.servlet;

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.URLEncoder;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;


import com.yuming.util.Base64Util;

/**
 * Servlet implementation class DownloadServlet
 */
public class DownloadServlet extends HttpServlet {

		protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
			
			//1. 获取要下载的文件名字 aa.jpg  --- inputStream
			String fileName = request.getParameter("filename");
			
			//get请求,这个fileName有中文
			fileName = new String(fileName.getBytes("UTF-8"),"UTF-8");
			System.out.println("fileName="+fileName);
			
			
			//2. 获取这个文件在tomcat里面的绝对路径地址
			String path = getServletContext().getRealPath("download/"+fileName);
			
			/**
			 * 如果文件的名字带有中文,需要对文件名进行编码处理
			 * 
			 * IE/chrome 使用URLEncoding编码
			 * 
			 * Firefox ,使用base64 编码
			 */
			String clientType = request.getHeader("User-Agent");
			if(clientType.contains("Firefox")){
				fileName = Base64Util.base64EncodeFileName(fileName);
			}else{
				//IE ,或者  Chrome (谷歌浏览器) ,
				//对中文的名字进行编码处理
				fileName = URLEncoder.encode(fileName, "
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值