Weblogic读不到Word文件

简介: Weblogic读不到Word文件          之前遇到一导出word文件的需求,我的做法是把对应导出内容放到一个word文件中,把其中变化的内容作为变量,然后把该word文件放在WEB-INF目录下用来作为模板。

Weblogic读不到Word文件

 

       之前遇到一导出word文件的需求,我的做法是把对应导出内容放到一个word文件中,把其中变化的内容作为变量,然后把该word文件放在WEB-INF目录下用来作为模板。在导出时通过ServletContextgetRealPath()方法获取到作为模板的word文件的真实路径,然后针对该路径new一个FileInputStream。之后通过该wordInputStream构造一个HWPFDocument,再对里面的变量进行替换后输出到response的输出流中。大概代码如下所示:

 
@WebServlet("/servlet/word/export.do")
public class WordExportorServlet extends HttpServlet {
 
   /**
    * serialVersionUID
    */
   private static final long serialVersionUID = 1L;
 
   @Override
   protected void doGet(HttpServletRequest request, HttpServletResponse response)
         throws ServletException, IOException {
      this.doPost(request, response);
   }
 
   @Override
   protected void doPost(HttpServletRequest request, HttpServletResponse response)
         throws ServletException, IOException {
      String wordName = "中国人";  //假设这是我们word文档导出的文件名
      //假设这里获取到了word模板文件的相对于ServletContext根的路径
      String path = "/template.doc";
      ServletContext context = getServletContext();
      //获取word模板文件的绝对路径
      String realPath = context.getRealPath(path);
      //获取到作为模板的word文件的输入流
      InputStream is = new FileInputStream(realPath);
      HWPFDocument doc = new HWPFDocument(is);
      Range range = doc.getRange();
      //替换变量
      range.replaceText("${xx}", "xxx");
      response.setHeader("Content-Disposition", "attachment;filename=" + this.getFileName(wordName) + "");
       OutputStream output = response.getOutputStream();
       doc.write(output);
       output.close();
       is.close();
   }
  
   /**
    * 把wordName以ISO-8859-1编码,同时加上“.doc”后缀进行返回。
    * @param wordName 要导出的word文件的名称
    * @return
    */
   private String getFileName(String wordName) {
      try {
         wordName = new String(wordName.getBytes("UTF-8"), "ISO-8859-1"); //防中文乱码
      } catch (UnsupportedEncodingException e) {
         e.printStackTrace();
      }
      return wordName + ".doc";
   }
 
}

 

       这种方式放在tomcatrunJetty上都是没有问题的,但是一旦打包放到weblogic上就不行了。原因是weblogic上访问的是未解压的包里面的内容,这个时候通过ServletContextgetRealPath()方法是获取不到模板文件基于硬盘的真实路径的,从而导致获取不到模板文件的输入流,也就不能利用它来生成新的Word文档进行导出了。解决方法是在获取模板文件对应的输入流时不要通过ServletContext获取到文件的真实路径后再通过FileInputStream去取对应的输入流,而是直接通过ServletContextgetResourceAsStream()方法来获取到ServletContext环境下的资源作为输入流。建议以后需要在Web环境下获取资源文件时都通过getResourceAsStream()来获取。

@WebServlet("/servlet/word/export.do")
public class WordExportorServlet extends HttpServlet {
 
   /**
    * serialVersionUID
    */
   private static final long serialVersionUID = 1L;
 
   @Override
   protected void doGet(HttpServletRequest request, HttpServletResponse response)
         throws ServletException, IOException {
      this.doPost(request, response);
   }
 
   @Override
   protected void doPost(HttpServletRequest request, HttpServletResponse response)
         throws ServletException, IOException {
      String wordName = "中国人";  //假设这是我们word文档导出的文件名
      //假设这里获取到了word模板文件的相对于ServletContext根的路径
      String path = "/template.doc";
      ServletContext context = getServletContext();
      //获取到作为模板的word文件的输入流
      InputStream is = context.getResourceAsStream(path);
      HWPFDocument doc = new HWPFDocument(is);
      Range range = doc.getRange();
      //替换变量
      range.replaceText("${xx}", "xxx");
      response.setHeader("Content-Disposition", "attachment;filename=" + this.getFileName(wordName) + "");
        OutputStream output = response.getOutputStream();
        doc.write(output);
        output.close();
        is.close();
   }
  
   /**
    * 把wordName以ISO-8859-1编码,同时加上“.doc”后缀进行返回。
    * @param wordName 要导出的word文件的名称
    * @return
    */
   private String getFileName(String wordName) {
      try {
         wordName = new String(wordName.getBytes("UTF-8"), "ISO-8859-1"); //防中文乱码
      } catch (UnsupportedEncodingException e) {
         e.printStackTrace();
      }
      return wordName + ".doc";
   }
 
}

 

 

 

(注:本文是基于poi3.9所写)

目录
相关文章
|
应用服务中间件
weblogic 配置文件说明
weblogic.xml http://download.oracle.com/docs/cd/E13222_01/wls/docs90/webapp/weblogic_xml.
550 0
|
应用服务中间件 数据格式 XML
|
4月前
|
Java 应用服务中间件 Linux
centos7安装weblogic
centos7安装weblogic
106 1
|
负载均衡 Java 应用服务中间件
Weblogic的了解、安装及其使用(三)
Weblogic的了解、安装及其使用
1411 0
|
Oracle Java 关系型数据库
Weblogic的了解、安装及其使用(二)
Weblogic的了解、安装及其使用
1034 0
|
开发框架 Kubernetes 监控
Weblogic的了解、安装及其使用(一)
Weblogic的了解、安装及其使用
2565 0
|
安全 Oracle Java
Oracle Weblogic--CentOS Linux 8.5.2安装weblogic11G
Weblogic在centos上详细安装步骤及安装过程中可能遇到的问题
343 0
Oracle Weblogic--CentOS Linux 8.5.2安装weblogic11G