`
long_yu2
  • 浏览: 338198 次
社区版块
存档分类
最新评论

Java根据word模板生成word文档之后台解析和实现及部分代码(二)

    博客分类:
  • java
阅读更多

       上一节贴出了web应用访问生成报告的action和service层的关键2个方法。并提到了调用了httpclient方法去执行报告服务器上的方法,从而返回数据流。下面主要是看报告服务器上的方法是怎么样的?

        首先还是要说明一下,我们的web服务器都是linux环境,而之所以要用到httpclient和单独的报告服务器就是解决jacob不支持linux 服务器的问题,所以将生成word报告的工作交给了报告服务器去做,这样无形也减轻了web应用服务器的压力,下面从httpclient·反问开始:

如:httpclient·的url如下:

    

[java] view plain copy
  1. String url =  "http://"  +  this .getRepIpUrl() +  "/infoDisposal/<span style=" color: rgb( 51 51 51 ); font-family: Arial; font-size: 14px; line-height: 26px;  ">creatdocrep</span>.action?docType="  + docType +  "&projectId="  + projectId +  "&userId="  + userId +  "&workgroupId="  + workgroupId +  "&evtcaseInstId="  + evtcaseInstId;  

 

注:这里可以使用https也是可以的,看项目需要怎么配置


然后我跟着这个地址找到了报告服务器上的类和方法:

找到了creatDocRep.action

其方法如下:

[java] view plain copy
  1. /**  
  2.   * 获取文件流对象  
  3.   * @param inputPath  
  4.   * @return InputStream 文件流对象  
  5.   * @throws Exception  
  6.   */   
  7.  public  InputStream getInputStream(){  
  8.     InputStream inputStream = null ;  
  9.     Map<String,String> paramMap = new  HashMap<String,String>();  
  10.     //获取模版类型   
  11.     String docType = Struts2Utils.getParameter("docType" );  
  12.     Integer docType_i = 0 ;  
  13.     if (CommonUtils.isNotNull(docType)){  
  14.         docType_i = Integer.parseInt(docType);  
  15.     }  
  16.     //获取用户id   
  17.     String userId = Struts2Utils.getParameter("userId" );  
  18.     //MAP对象参数   
  19.     String projectId = Struts2Utils.getParameter("projectId" );  
  20.     //获取参数MAP   
  21.     paramMap.put("project_id" , projectId);  
  22.     //获取组组编号参数   
  23.     String workgroupId = Struts2Utils.getParameter("workgroupId" );  
  24.     if (CommonUtils.isNotNull(workgroupId) && !workgroupId.equals( "null" )){  
  25.         paramMap.put("workgroupId" , workgroupId);  
  26.     }  
  27.     //获取评估用例实例ID参数   
  28.     String evtcaseInstId = Struts2Utils.getParameter("evtcaseInstId" );  
  29.     if (CommonUtils.isNotNull(evtcaseInstId)){  
  30.         paramMap.put("evtcase_inst_id" , evtcaseInstId);  
  31.     }  
  32.       
  33.     if (CommonUtils.isNotNull(userId)){  
  34.         paramMap.put("userId" , userId);  
  35.     }  
  36.     //获取模版路径   
  37.     String xmlTempUrl = xmlPathDef.getXmlPath(docType);  
  38.       
  39.     //设置打开word模版路径   
  40.     String docPath = "" ;  
  41.     //取得对应的模版路径   
  42.     TTemplIdx templIdx = templIdxService.findFileByType(Integer.parseInt(XmlPathDef.TEMPL_IDX_1),Integer.parseInt(docType));  
  43.     if (templIdx !=  null ){  
  44.         docPath = xmlPathDef.getPath(XmlPathDef.getBasePath() + templIdx.getTemplFileName());  
  45.         try  {  
  46.             String outPath = infoSystemDescService.showWordRp(xmlTempUrl, docType_i, paramMap, docPath);  
  47.             if (CommonUtils.isNotNull(outPath)){  
  48.                 inputStream = ServletActionContext.getServletContext().getResourceAsStream(xmlPathDef.getRealRepPath(outPath,projectId,docType,workgroupId));  
  49.             }  
  50.         } catch  (Exception e) {  
  51.             logger.error("没有创建成功" );  
  52.             e.printStackTrace();  
  53.         }  
  54.     }  
  55.     return  inputStream;  
  56.   }  

 

主要是调用了service层的方法,这里主要也是传入了相关的参数和取得了word报告模板路径,创建word文档,然后返回流文件。

 

然后再看service层方法:

[java] view plain copy
  1. /**  
  2.        * 生成报告(doc文档)  
  3.        * @param  xmlTempUrl 模版路径  
  4.        * @param  docType  要生成的报告类型  
  5.        * @param  paramMap  报告参数  
  6.        * @param  webName  要展示的报告名称  
  7.        * @param  filename   报告文件名称  
  8.        * @param  docId   报告文件主键  
  9.        * @param  version  报告文件版本  
  10.        * @param  docPath  报告路径  
  11.        * @param  outRepPath  报告生成的路径  
  12.        * @return  
  13.        * @throws Exception  
  14.      */   
  15.     public  String showWordRp(String xmlTempUrl,Integer docType,Map<String,String> paramMap,String docPath)  throws  Exception {  
  16.         boolean  boo=  true ;  
  17.         String outRepPath = "" ;  
  18.         try  {  
  19.             Long projectId = 0l;  
  20.             Long workgroupId =0l;  
  21.             String evtcaseInstId ="" ;  
  22.             String userId ="" ;  
  23.             Set<Entry<String, String>> sets = paramMap.entrySet();  
  24.             Iterator<Entry<String, String>> it = sets.iterator();  
  25.             while  (it.hasNext()) {  
  26.                 Map.Entry<String,String> entry = (Map.Entry<String,String>) it.next();  
  27.                 String key = entry.getKey();  
  28.                 if (key.equals( "project_id" )){  
  29.                     projectId =  Long.parseLong(entry.getValue().toString());  
  30.                 }else   if (key.equals( "workgroupId" )){  
  31.                     workgroupId =  Long.parseLong(entry.getValue().toString());  
  32.                 }else   if (key.equals( "evtcase_inst_id" )){  
  33.                     evtcaseInstId =  entry.getValue();  
  34.                 }else   if (key.equals( "userId" )){  
  35.                     userId =  entry.getValue();  
  36.                 }  
  37.             }  
  38.               
  39.                     //获取Web项目名称   
  40.             //String webName = XmlPathDef.getWebName();   
  41.                      //获取文档表的最大主键值   
  42.             String docId = this .getMaxDocId(docType, workgroupId.toString(),projectId.toString());  
  43.             //获取最大版本   
  44.             String version = this .getMaxVersion(userId, docType, projectId, workgroupId.toString(), evtcaseInstId);  
  45.             //获取生成后的文档名称   
  46.             String filename = this .getFileName(docType, projectId,docId,version);  
  47.                  //获取生成后的文档路径   
  48.             outRepPath = xmlPathDef.getPath(xmlPathDef.getCreatWordPath(userId, docType.toString(), projectId.toString(),workgroupId.toString()) + filename);  
  49.               
  50.             //取得标签所对应的所有Map值   
  51.             HashMap<String,Object> map = this .getAllData(xmlTempUrl, paramMap,docType.toString());  
  52.             //省去了相关的业务操作..............   
  53.                  
  54.             try  {  
  55.                 System.out.println(" **************************报告类型为 ---> docType: " + docType);  
  56.                 Export2WordService export2WordService = new  Export2WordService();  
  57.                 //System.out.println("***************  开始调用 export2Word 方法    ********** 执行到InfoSystemDescService类 ");   
  58.                 boo = export2WordService.export2Word(docPath,outRepPath,map,docType.toString(),tbmap,tbvalue,testMap0,projectId,collect_feedback_auditValueMap,sccDatas,contentMap,sccContentMap,proEvtType);  
  59.                 //System.out.println("***************  调用 export2Word 完毕方法   开始去向数据库中添加数据   ********** 执行到InfoSystemDescService类 ");   
  60.                 if (boo){ //说明创建报告成功,然后保存到数据库   
  61.                     if (CommonUtils.isNotNull(docId)){  
  62.                         //生成后的word文档对象   
  63.                         TProjDoc doc = new  TProjDoc();  
  64.                         //设置需要保存的参数   
  65.                         doc.setDocId(docId);  
  66.                         doc.setDispName(repName);  
  67.                         doc.setFilename(filename);  
  68.                         doc.setPath(xmlPathDef.getRealRepPath(outRepPath,projectId.toString(),docType.toString(),workgroupId.toString()));//对应数据库中的相对路径   
  69.                         doc.setType(docType);  
  70.                         doc.setVersion(Integer.parseInt(version));  
  71.                         doc.setCreateTime(new  Timestamp(System.currentTimeMillis()));  
  72.                         doc.setSuffix(Short.parseShort("2" ));  
  73.                         TProject proj = new  TProject();  
  74.                         proj.setProjectId(projectId);  
  75.                         doc.setTProject(proj);  
  76.                         doc.setUserId(userId);  
  77.                         doc.setWorkgroupId(workgroupId);  
  78.                         doc.setEvtcaseInstId(evtcaseInstId);  
  79.                         projDocDao.save(doc);  
  80.                           
  81.                        }  
  82.                     }else {  
  83.                         //如果没有创建成功就删除原来的文件   
  84.                         File file = new  File(outRepPath);  
  85.                         file.delete();    
  86.                 }  
  87.             } catch  (Exception e) {  
  88.                 logger.error("创建 Word.Application 失败!"  + e.getMessage());    
  89.             }  
  90.               
  91.         } catch  (Exception e) {  
  92.             logger.error("创建报告失败!"  + e.getMessage());    
  93.             e.printStackTrace();     
  94.         }  
  95.         return  outRepPath;  
  96.     }  

 

这里主要:

1.调用工具类来解析XML定义文档,并获取到数据集Map

2.调用jacob的封装类,根据相关的数据集生成word报告

3,一旦word穿件成功,就往数据库中写入一条记录

 

分享到:
评论

相关推荐

    java 根据word模板生成word 文档

    Java作为一种广泛使用的编程语言,提供了多种方法来根据Word模板生成Word文档,而Jacob库就是其中一种非常实用且功能强大的解决方案。 #### Jacob库简介 Jacob(Java and COM Bridge)是一个开源的Java类库,它...

    java XML解析方式实现自动生成word文档

    以下是一个基本的步骤,展示如何使用Java和Apache POI通过XML解析生成Word文档: 1. 引入Apache POI库:在项目中添加Apache POI依赖,通常是通过Maven或Gradle的配置完成。 2. 创建Word文档对象:使用`...

    java代码实现填充word模板生成word合同的实例

    本实例将探讨如何使用Java代码实现填充Word模板并生成Word合同。 首先,我们需要理解Apache POI库。Apache POI是Java平台上的一个开源项目,它允许Java应用程序读取、写入和修改Microsoft Office格式的文件,包括...

    java根据模版生成带图片的word文档

    总的来说,通过Java结合Freemarker和Apache POI,我们可以高效地根据模板生成带有图片的Word文档,这一技术在许多业务场景中都有广泛的应用。在实践中,需要注意数据安全、性能优化以及兼容性问题,确保生成的文档...

    Java根据word 模板,生成自定义内容的word 文件

    Java提供了一些强大的库来实现这个功能,其中就包括利用Word模板生成自定义内容。在这个案例中,我们将探讨如何使用Java,结合XML、Freemarker等技术,来实现这一目标。 首先,让我们了解一下核心的Java库Apache ...

    JavaGenWord-根据模板生成word文档

    JavaGenWord是一个基于Java语言的工具,用于根据预先定义的模板生成Word文档。这个过程主要依赖于FreeMarker库,这是一个强大的、开源的模板引擎,广泛应用于生成动态内容,如HTML、XML、PDF或如本例中的Word文档。...

    java-根据word模板生成word-freemarker-完整示例

    本示例主要展示了如何使用Freemarker根据XML模板生成Word文档。以下是对这一技术的详细解释: 1. **Freemarker简介**: Freemarker是一个开源的Java库,它能够将数据模型与HTML、XML或其他文本格式的模板结合,...

    Java Poi流 根据Word模板插入相应的文本、表格和图片,生成新的Word报告

    在本主题中,我们将深入探讨如何使用Java POI流处理Word模板,插入文本、表格和图片,以及生成新的Word报告。 1. **Java POI流处理Word模板**: - POI API提供了`XWPFDocument`类来处理`.docx`文件,这是Word 2007...

    Java根据ftl模板生成多表格复杂性word文档

    这表明它可能包含了一个完整的Java应用程序,该程序加载数据模型,解析FTL模板,然后使用Apache POI生成Word文档。用户可能只需要修改数据模型和FTL模板,即可满足自己的定制化需求。 在实际应用中,这样的解决方案...

    JAVA根据模板生成word文件

    在Java中,有多种库可以帮助我们根据模板生成Word文档,例如Apache POI、FreeMarker和Thymeleaf等。Apache POI是Java中广泛使用的处理Microsoft Office格式文件的库,包括Word(.doc/.docx)文件。FreeMarker和...

    java使用word模板导出个人简历

    本教程将探讨如何利用Java和特定的模板引擎,如Freemarker,来处理Word模板,生成doc和docx格式的个人简历文件。以下是相关知识点的详细说明: 1. **Freemarker模板引擎**: Freemarker是一个强大的、开源的模板...

    Java操作Word模板实现动态数据输出

    ### Java操作Word模板实现动态数据输出 #### 一、引言 随着信息技术的发展,特别是数据库技术和网络技术的进步,许多企事业单位对于内部数据管理和外部信息发布的方式也在不断演变。当前,大多数单位倾向于将数据...

    freemarker模板技术生成复杂word文档---解决了编码问题

    3.写java程序根据模板生成word 总结,之前在网上查到这个资料怎么调试都失败,后来经过反复查找发现是编码问题导致生成word格式错误,已经修正,希望能给大家带来帮助。 效率测试生成100000行数据大概4000毫秒...

    java itext生成多页的word模板

    总的来说,利用Java的iText库生成多页的Word模板需要一定的技巧和对PDF及Office文档格式的理解。通过结合不同库的功能,我们可以创建出满足需求的复杂文档模板。对于中文支持,正确选择和注册字体是至关重要的,同时...

    Android 使用模板生成Word文档的demo,最新版在Android studio中运行

    本示例项目“Android使用模板生成Word文档的demo”提供了一种解决方案,它利用Apache POI库在Android Studio中运行,使开发者能够在Android设备上创建和编辑Microsoft Word文档。下面我们将深入探讨这个项目的细节...

    Java通过模版生成word文档

    Java通过模板生成Word文档是结合FreeMarker和Apache POI的一种有效策略,它使得Java程序能够方便地生成结构化的文档。在实际应用中,可以根据项目需求选择合适的模板引擎,并灵活运用相关库,实现高效、定制化的Word...

    Java操作word模板读写

    总的来说,Java操作Word模板读写是一个涉及文件I/O、XML解析和文档格式理解的综合任务,通过Apache POI等库,我们可以方便地实现这一目标。在实际开发中,根据需求选择合适的方法和工具,以提高效率和灵活性。

    Java生成word文档(仅一个文档模板原件和转换后缀为.ftl格式文件)

    总之,Java通过FreeMarker和Apache POI的结合,可以实现动态生成Word文档的功能。这个过程涉及到模板的创建和转换、数据模型的设计、FreeMarker的配置和使用,以及可能的性能优化和异常处理。掌握这些知识点,能帮助...

    java freemarker导出word -包含多张图片导出

    5. **生成Word文档** 使用Apache POI创建一个新的Word文档,并在其中添加FreeMarker模板。在模型中设置图片对象,然后使用FreeMarker的`Template`类将模板和模型合并,生成最终的Word文档内容。 6. **嵌入图片** ...

Global site tag (gtag.js) - Google Analytics