之前在写下载文件的时候用的是下面没有if的else部分的代码,在chrome和360浏览器下都是正常的,但是在firefox下却是乱码(编码)的情况,之前在网上找到相应的文章,红色部分代码为后加上去的,放上去之后确实OK,filename为我们要下载的文件的文件名(包含后缀),RFC 2183规定filename只能为US-ASCII码,然而现代浏览器中许多已经支持UTF-8编码了,但各个浏览器的支持规则不同。在IE、chrome中,可以直接用filename作为下载文件的名称,但是Firefox却不支持这样。我们直接上代码吧。
this.context.Response.Charset = "UTF-8";
this.context.Response.ContentEncoding = System.Text.Encoding.UTF8;
string filename = HttpUtility.UrlEncode(nvcOriginalName.Trim(), System.Text.Encoding.UTF8);
if (this.context.Request.UserAgent.ToLower().IndexOf("firefox") > -1)
{
this.context.Response.AddHeader("Content-Disposition", "attachment; filename*=UTF-8''" + filename);
}
else
{
this.context.Response.AddHeader("Content-Disposition", "attachment;filename=" + filename);
}
this.context.Response.AddHeader("Content-Length", file.Length.ToString());
this.context.Response.ContentType = MimeType.GetMimeTypeFromPath(path);
this.context.Response.WriteFile(file.FullName);
this.context.Response.Flush();
this.context.Response.Clear();
//设置要下载的文件的媒体格式
response.setContentType(this.getServletContext().getMimeType(filename));
//处理中文文件下载时火狐浏览器中文文件名乱码的问题
//从请求头中获取User-Agent判断当前使用的是否是火狐浏览器
String header = request.getHeader("User-Agent");
if(header.contains("Firefox")){
//说明是火狐浏览器,使用Base64Encoder类进行编码
BASE64Encoder base = new BASE64Encoder();
filename = "=?utf-8?B?"+base.encode(filename.getBytes("utf-8"))+"?=";
}else{
//是其他浏览器,使用URLEncoder类进行编码
filename = URLEncoder.encode(filename,"utf-8");
}
//设置要被下载的文件名
response.setHeader("Content-Disposition","attachment;filename="+filename);
版权声明:本文为CSDN博主「梦里Ta归」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qsw2lw/article/details/84004403
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/tengqingyong/article/details/79943971