Struts2 文件下载及中文乱码问题的解决方案

[b]今天修改了一个一直悬而未决的问题,非常高兴!写下这个解决方案。[/b]

一 struts.xml文件的编辑
<struts>
<package name="crud-default" extends="convention-default">
<action name="download" class="com.myweb.download.DownLoadAction">
<!--type 为 stream 应用 StreamResult 处理-->
<result name="success" type="stream">
<!--默认为 text/plain-->
<param name="contentType">application/x-msdownload;charset=ISO8859-1</param>
<!-- 默认就是 inputStream,它将会指示 StreamResult 通过 inputName 属性值的 getter 方法,
比如这里就是 getInputStream() 来获取下载文件的内容,意味着你的 Action 要有这个方法 -->
<param name="inputName">inputStream</param>
<!-- 默认为 inline(在线打开),设置为 attachment 将会告诉浏览器下载该文件,filename
指定下载文件时的文件名,若未指定将会是以浏览的页面名作为文件名,如以 download.action 作为文件名 -->
<param name="contentDisposition">attachment;filename="${fileName}"</param>
<!-- 输出时缓冲区的大小 -->
<param name="bufferSize">4096</param>
</result>
</action>
</package>
</struts>
二,com.myweb.download.DownLoadAction 的文件的代码
public class DownLoadAction extends ActionBase {
private Logger logger = LoggerFactory.getLogger(DownLoadAction.class);
private String fileName = null;
public String execute() throws Exception {
return "success";
}
public InputStream getInputStream() {
this.fileName = json.substring(json.lastIndexOf("\\") + 1, json.length());
return Struts2Utils.getSession().getServletContext().getResourceAsStream(json);
}

public String getFileName() {
try {
Struts2Utils.getResponse().setHeader("charset","ISO8859-1");
return new String(this.fileName.getBytes(), "ISO8859-1");
} catch (UnsupportedEncodingException e) {
return "获取文件名出现了错误!";
}
}
}

[size=large][b]遇到的问题:[/b][/size]

文件可以下载,但是在websphere环境下,下载的文件的中文名是乱码,解决问题的步骤如下:
第一,修改了struts.xml文件


[img]http://dl.iteye.com/upload/attachment/268842/bece1df2-4d3a-39fc-a2b4-507f0074896b.png[/img]


第二,修改了DownLoadAction.java文件的getFileName方法

public String getFileName() {
try {
return new String(this.fileName.getBytes(), "ISO8859-1");
} catch (UnsupportedEncodingException e) {
return "获取文件名出现了错误!";
}
}

在新弹出IE窗口中,第一次下载时,下载提示框中文仍然是乱码, 再次下载,就可以正常显示中文。整个应用软件包
的默认编码是UTF-8, 在第一次下载之后,客户端浏览器的默认编码被修改为ISO8859-1,再次下载中文就可以正常
显示,因为这时候IE浏览器的字符集编码是西欧ISO

[img]http://dl.iteye.com/upload/attachment/268844/8f2235ed-1fb2-3985-8de8-85940dae4a35.png[/img]

如上图所示,浏览器的默认编码从UTF-8修改为西欧ISO
那我们又该如何解决这个第一次下载时出现乱码的问题呢?

第三,继续修改DownLoadAction.java文件的getFileName方法

public String getFileName() {
try {
[b]
[color=green]
//在服务器端通过设置http Header, 设置了客户端的默认的字符集编码 [/color]
Struts2Utils.getResponse().setHeader("charset","ISO8859-1"); [/b]
return new String(this.fileName.getBytes(), "ISO8859-1");
} catch (UnsupportedEncodingException e) {
return "获取文件名出现了错误!";
}
}

[b]附: 如果整体修改为UTF-8下载反而会出现"未知的文件名"的错误提示,http请求中默认的编码有可能是ISO8859-1[/b]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值