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

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

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

如:httpclient·的url如下:

    

String url = "http://" + this.getRepIpUrl() + "/infoDisposal/creatdocrep.action?docType=" + docType + "&projectId=" + projectId + "&userId=" + userId + "&workgroupId=" + workgroupId + "&evtcaseInstId=" + evtcaseInstId;

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


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

找到了creatDocRep.action

其方法如下:

 /**
	  * 获取文件流对象
	  * @param inputPath
	  * @return InputStream 文件流对象
	  * @throws Exception
	  */
	 public InputStream getInputStream(){
		InputStream inputStream = null;
		Map<String,String> paramMap = new HashMap<String,String>();
		//获取模版类型
		String docType = Struts2Utils.getParameter("docType");
		Integer docType_i = 0;
		if(CommonUtils.isNotNull(docType)){
			docType_i = Integer.parseInt(docType);
		}
		//获取用户id
		String userId = Struts2Utils.getParameter("userId");
		//MAP对象参数
		String projectId = Struts2Utils.getParameter("projectId");
		//获取参数MAP
		paramMap.put("project_id", projectId);
		//获取组组编号参数
		String workgroupId = Struts2Utils.getParameter("workgroupId");
		if(CommonUtils.isNotNull(workgroupId) && !workgroupId.equals("null")){
			paramMap.put("workgroupId", workgroupId);
		}
		//获取评估用例实例ID参数
		String evtcaseInstId = Struts2Utils.getParameter("evtcaseInstId");
		if(CommonUtils.isNotNull(evtcaseInstId)){
			paramMap.put("evtcase_inst_id", evtcaseInstId);
		}
		
		if(CommonUtils.isNotNull(userId)){
			paramMap.put("userId", userId);
		}
		//获取模版路径
		String xmlTempUrl = xmlPathDef.getXmlPath(docType);
		
		//设置打开word模版路径
		String docPath = "";
		//取得对应的模版路径
		TTemplIdx templIdx = templIdxService.findFileByType(Integer.parseInt(XmlPathDef.TEMPL_IDX_1),Integer.parseInt(docType));
		if(templIdx != null){
			docPath = xmlPathDef.getPath(XmlPathDef.getBasePath() + templIdx.getTemplFileName());
			try {
				String outPath = infoSystemDescService.showWordRp(xmlTempUrl, docType_i, paramMap, docPath);
				if(CommonUtils.isNotNull(outPath)){
					inputStream = ServletActionContext.getServletContext().getResourceAsStream(xmlPathDef.getRealRepPath(outPath,projectId,docType,workgroupId));
				}
			} catch (Exception e) {
				logger.error("没有创建成功");
				e.printStackTrace();
			}
		}
		return inputStream;
	  }


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


然后再看service层方法:

/**
	   * 生成报告(doc文档)
	   * @param  xmlTempUrl 模版路径
	   * @param  docType  要生成的报告类型
	   * @param  paramMap  报告参数
	   * @param  webName  要展示的报告名称
	   * @param  filename   报告文件名称
	   * @param  docId   报告文件主键
	   * @param  version  报告文件版本
	   * @param  docPath  报告路径
	   * @param  outRepPath  报告生成的路径
	   * @return
	   * @throws Exception
	 */
	public String showWordRp(String xmlTempUrl,Integer docType,Map<String,String> paramMap,String docPath) throws Exception {
		boolean boo= true;
		String outRepPath = "";
		try {
		    Long projectId = 0l;
		    Long workgroupId =0l;
		    String evtcaseInstId ="";
		    String userId ="";
		    Set<Entry<String, String>> sets = paramMap.entrySet();
		    Iterator<Entry<String, String>> it = sets.iterator();
	        while (it.hasNext()) {
	            Map.Entry<String,String> entry = (Map.Entry<String,String>) it.next();
	            String key = entry.getKey();
	            if(key.equals("project_id")){
	            	projectId =  Long.parseLong(entry.getValue().toString());
	            }else if(key.equals("workgroupId")){
	            	workgroupId =  Long.parseLong(entry.getValue().toString());
	            }else if(key.equals("evtcase_inst_id")){
	            	evtcaseInstId =  entry.getValue();
	            }else if(key.equals("userId")){
	            	userId =  entry.getValue();
	            }
		    }
	        
	                //获取Web项目名称
			//String webName = XmlPathDef.getWebName();
	                 //获取文档表的最大主键值
			String docId = this.getMaxDocId(docType, workgroupId.toString(),projectId.toString());
			//获取最大版本
			String version = this.getMaxVersion(userId, docType, projectId, workgroupId.toString(), evtcaseInstId);
			//获取生成后的文档名称
			String filename = this.getFileName(docType, projectId,docId,version);
		         //获取生成后的文档路径
			outRepPath = xmlPathDef.getPath(xmlPathDef.getCreatWordPath(userId, docType.toString(), projectId.toString(),workgroupId.toString()) + filename);
	        
			//取得标签所对应的所有Map值
			HashMap<String,Object> map = this.getAllData(xmlTempUrl, paramMap,docType.toString());
			//省去了相关的业务操作..............
		       
			try {
				System.out.println(" **************************报告类型为 ---> docType: "+ docType);
				Export2WordService export2WordService = new Export2WordService();
				//System.out.println("***************  开始调用 export2Word 方法    ********** 执行到InfoSystemDescService类 ");
				boo = export2WordService.export2Word(docPath,outRepPath,map,docType.toString(),tbmap,tbvalue,testMap0,projectId,collect_feedback_auditValueMap,sccDatas,contentMap,sccContentMap,proEvtType);
				//System.out.println("***************  调用 export2Word 完毕方法   开始去向数据库中添加数据   ********** 执行到InfoSystemDescService类 ");
				if(boo){//说明创建报告成功,然后保存到数据库
					if(CommonUtils.isNotNull(docId)){
						//生成后的word文档对象
						TProjDoc doc = new TProjDoc();
						//设置需要保存的参数
						doc.setDocId(docId);
						doc.setDispName(repName);
						doc.setFilename(filename);
						doc.setPath(xmlPathDef.getRealRepPath(outRepPath,projectId.toString(),docType.toString(),workgroupId.toString()));//对应数据库中的相对路径
						doc.setType(docType);
						doc.setVersion(Integer.parseInt(version));
						doc.setCreateTime(new Timestamp(System.currentTimeMillis()));
						doc.setSuffix(Short.parseShort("2"));
						TProject proj = new TProject();
						proj.setProjectId(projectId);
						doc.setTProject(proj);
						doc.setUserId(userId);
						doc.setWorkgroupId(workgroupId);
						doc.setEvtcaseInstId(evtcaseInstId);
						projDocDao.save(doc);
						
					   }
					}else{
						//如果没有创建成功就删除原来的文件
						File file = new File(outRepPath);
						file.delete();	
				}
			} catch (Exception e) {
				logger.error("创建 Word.Application 失败!" + e.getMessage());  
			}
			
		} catch (Exception e) {
			logger.error("创建报告失败!" + e.getMessage());  
			e.printStackTrace();   
		}
		return outRepPath;
	}


这里主要:

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

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

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


未完待续



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java导出Word文档可以利用Apache POI和Freemarker模板引擎来实现。 Apache POI是一个用于操作Microsoft Office文档Java API。它提供了对Word文档的读取、创建和修改的功能。通过使用Apache POI,可以轻松地在Java代码中创建一个空的Word文档,并添加文本、表格、图片等内容。同时,还可以设置文档的样式、格式和布局等,以满足不同的需求。 而Freemarker模板引擎则是用于生成动态文本输出的工具。它基于模板和数据模型,可以将数据动态填充到指定的Word模板中,生成最终的Word文档。使用Freemarker模板引擎可以使文档生成更加灵活和可扩展,根据不同的数据模型生成不同的文档内容,提高了代码的可维护性和重用性。 要实现导出Word文档的功能,首先需要引入Apache POI和Freemarker的相关依赖库。接下来,创建一个空的Word文档,使用Apache POI的API对文档进行操作,例如添加标题、段落、表格等内容,以及设置样式和格式。然后,结合Freemarker模板引擎,根据自定义的数据模型填充数据到Word模板中,生成最终的Word文档。 通过以上的方法,利用Apache POI和Freemarker模板引擎可以轻松地实现Java导出Word文档的功能。这种方式方便、灵活,适用于需要动态生成Word文档的各种场景,例如报告生成、合同生成等。同时,这两个工具库都有良好的文档和丰富的示例代码,方便开发者进行学习和使用。 ### 回答2: Java 导出 Word 文档利用 Apache POI 和 FreeMarker 模板引擎的基本步骤如下: 1. 首先,确保你的项目已经导入了 Apache POI 和 FreeMarker 的相关依赖。 2. 创建一个 Word 文档模板,可以使用 Microsoft Office 软件创建一个空白文档,并将需要的样式和占位符添加到模板中。占位符可以使用自定义的标记,例如 `${name}`。 3. 在 Java 代码中,使用 Apache POI 创建一个 Word 文档对象 `XWPFDocument`。例如:`XWPFDocument document = new XWPFDocument();`。 4. 使用 FreeMarker 模板引擎加载并解析 Word 文档模板。创建一个 `Configuration` 对象,并设置模板文件的路径或类路径。例如:`Configuration configuration = new Configuration(Configuration.VERSION_2_3_23);`。 5. 根据模板文件路径或类路径加载模板文件。例如:`Template template = configuration.getTemplate("template.docx");`。 6. 创建一个数据模型,将数据填充到模板中。可以使用 `Map` 或自定义的 Java 对象作为数据模型。例如:`Map<String, String> data = new HashMap<>();`,然后将需要填充的数据放入 `data` 中。 7. 使用 FreeMarker 模板引擎的 `process` 方法将数据模型与模板进行合并,生成最终的 Word 文档内容。例如:`StringWriter writer = new StringWriter();`,`template.process(data, writer);`。 8. 将生成Word 文档内容写入到 Apache POI 的 `XWPFDocument` 对象中。可以使用 `OutputStream` 将内容写入到文档对象中。例如:`OutputStream outputStream = new FileOutputStream("output.docx");`,`writer.flush();`,`document.write(outputStream);`,`outputStream.close();`。 9. 最后,记得在使用完毕后关闭相关资源,例如关闭输出流、释放内存等。 以上就是利用 Apache POI 和 FreeMarker 模板引擎导出 Word 文档的基本步骤,通过动态填充数据,可以生成灵活且具有个性化内容的 Word 文档。 ### 回答3: Java导出Word文档可以使用Apache POI和Freemarker模板引擎相结合的方法来实现。Apache POI是一个用于处理Microsoft Office文档Java库,而Freemarker是一个基于模板的文本生成引擎。 首先,我们需要在项目中引入Apache POI和Freemarker的相关依赖。 然后,我们需要创建一个Word文档模板文件,模板文件中可以包含一些占位符,用于动态添加数据。比如,我们可以在模板文件中添加一个{{name}}的占位符。 接下来,在Java中,我们可以使用Freemarker来解析模板文件。首先,我们需要创建一个Configuration对象,并指定模板文件的路径。然后,我们可以使用Template类的getTemplate方法来获取模板对象。 接着,我们可以创建一个Map对象,将需要动态添加的数据放入其中。比如,我们可以将姓名(name)放入Map中。 然后,我们可以调用Template类的process方法来解析模板并将数据填充到占位符中。我们可以将解析后的结果保存在一个字符串中。 最后,我们可以使用Apache POI来创建一个新的Word文档。我们可以创建一个XWPFDocument对象,并使用其createParagraph方法来创建段落。然后,我们可以使用XWPFRun对象的setText方法将之前解析后的结果添加到段落中。 最后,我们可以将生成Word文档保存到指定路径。我们可以使用XWPFDocument对象的write方法将文档保存为文件。 综上所述,通过使用Apache POI和Freemarker模板引擎,我们可以方便地导出Word文档。我们只需要创建一个模板文件,使用Freemarker来解析模板并将数据填充到占位符中,然后使用Apache POI来创建新的文档并保存即可。这种方法可以加快开发速度,同时也使得代码结构更加清晰易读。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值