DBMNG数据库管理与应用

书籍是全世界的营养品。生活里没有书籍,就好像没有阳光;智慧里没有书籍,就好像鸟儿没有翅膀。
当前位置:首页 > 经验分享 > Java组件

解决struts文件下载的中文乱码问题

一 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 "获取文件名出现了错误!";  

        }  

    }  

}  


遇到的问题: 

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



 




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

Java代码  

public String getFileName() {  

      try {  

         return new String(this.fileName.getBytes(), "ISO8859-1");     

      } catch (UnsupportedEncodingException e) {  

         return "获取文件名出现了错误!";  

      }  

}  


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

 

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

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

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

附: 如果整体修改为UTF-8下载反而会出现"未知的文件名"的错误提示,http请求中默认的编码有可能是ISO8859-1 


本站文章内容,部分来自于互联网,若侵犯了您的权益,请致邮件chuanghui423#sohu.com(请将#换为@)联系,我们会尽快核实后删除。
Copyright © 2006-2023 DBMNG.COM All Rights Reserved. Powered by DEVSOARTECH            豫ICP备11002312号-2

豫公网安备 41010502002439号