- 浏览: 313886 次
文章分类
最新评论
-
luokery:
你把正常的代码放到try里面不就好了, 异常的时候就catch ...
巧用while循环避免执行除了异常处理的的另一个处理机制 -
java_doom:
这个行号根据什么来的 为什么不是连续的?
别拿Hadoop map key当id使 -
mixer_b:
...
写博客的那些事儿 -
flyfx:
谢谢谢谢
java break,continue,return 使用。【借鉴与改编】 -
andilyliao:
比起青鸟 我更鄙视大学。
北大青鸟就让你们这么鄙视吗.
上一节贴出了web应用访问生成报告的action和service层的关键2个方法。并提到了调用了httpclient方法去执行报告服务器上的方法,从而返回数据流。下面主要是看报告服务器上的方法是怎么样的?
首先还是要说明一下,我们的web服务器都是linux环境,而之所以要用到httpclient和单独的报告服务器就是解决jacob不支持linux 服务器的问题,所以将生成word报告的工作交给了报告服务器去做,这样无形也减轻了web应用服务器的压力,下面从httpclient·反问开始:
如:httpclient·的url如下:
[java]
view plain
copy
- 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
- /**
- * 获取文件流对象
- * @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层方法:
[java]
view plain
copy
- /**
- * 生成报告(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穿件成功,就往数据库中写入一条记录
发表评论
-
java如何终止线程
2012-04-24 21:38 1032对于线程的终止或者中断,由于java中Thread.stop方 ... -
ubuntu-11.10-server-i386学习笔记-网络基本配置
2012-04-23 22:11 9961. 静态IP地址配置 配置文件路径:/etc/networ ... -
ubuntu-11.10-server-i386学习笔记-Apache安装
2012-04-23 22:11 797第一步:先更新安装包缓存 1.1 sudo apt-get ... -
ubuntu-11.10-server-i386学习笔记-SVN版本服务器安装
2012-04-23 22:10 1041在安装SVN前,假设你的Apache已经安装好了。 ... -
ubuntu-11.10-server-i386学习笔记-SVN版本服务器-客户端测试
2012-04-23 22:10 708进入客户端测试之前,您应该确保svn服务器已经正确安装,如果您 ... -
svn服务器搭建经验总结
2012-04-23 22:09 958从最近几天的实验来看,svn(Subversion versi ... -
Java根据word模板生成word文档之后台解析和实现及部分代码(一)
2012-04-18 13:59 2039后台主要工作是解析XML定义的标签文件,并 ... -
单例类、final、抽象类
2012-04-15 23:53 1620前些日子一直没写博客,因为病了,所以就耽误了,现在好点了 ... -
怎样在架构中合理的设置request中的Lcoale
2012-04-15 23:51 1204相信很多朋友在做J2EE国际化的时候,很可能遇到这个问题 ... -
一个Java时间工具类
2012-04-14 21:50 974主要包含了对时间操作的一些工具方法,仅供参考吧! ... -
POI Excel导出,我的又一个模板方法
2012-04-14 21:49 2759下面有源码,下载就可以用,如果因为包的问题,就拷贝我 ... -
Poi 读写Excel 合并ExcelSheet Struts2实现
2012-04-14 21:48 1450网上有许多人在找这样的例子,有多个Excel,要把他们合 ... -
POI读取Excel浅谈
2012-04-14 21:48 838先看代码,挨句解释: 一般遍历使用两种方式,1:得到总 ... -
struts2项目中静态html在firefox下乱码的解决
2012-04-13 00:03 942struts2 项目,通常开 ... -
黑马程序员——Java开发前奏
2012-04-12 23:59 780对于Java,我的一 ... -
《JAVA与模式》之单例模式
2012-04-12 23:58 732在阎宏博士的《JAVA与模式》一书中开头是这样描述单例模 ... -
Java中的String不再纠结
2012-04-12 23:58 1424又是新的一月,又是各种总结,先分享一下java中st ... -
swing绘制了一只直升机
2012-04-12 23:56 3385周末用swing绘制了一只直升机 对swing的的绘制技 ...
相关推荐
java XML解析方式实现自动生成word文档,文档中主要描述word模板的使用方法,文件中带有案例代码,可以方便理解
3.写java程序根据模板生成word 总结,之前在网上查到这个资料怎么调试都失败,后来经过反复查找发现是编码问题导致生成word格式错误,已经修正,希望能给大家带来帮助。 效率测试生成100000行数据大概4000毫秒...
POI读word文档还行,写文档实在不敢恭维,复杂的样式很难控制不提,想象一下一个20多页,嵌套很多表格和图像的word文档靠POI来写代码输出,对程序员来说比去山西挖煤还惨,况且文档格式还经常变化。 iText操作...
使用freemarker生成word ,并集成struts2 同时生成及下载文档 资料附有Java源代码和自己总结的使用说明及注意事项 大至预览如下: 1、用word编辑好模板 普通字符串替换为 ${string} 表格循环用标签 姓名:${...
先创建一个word文档,按照需求在word中填好一个模板,然后将文档保存为xml文档格式,使用文档编辑器打开这个xml格式的文档(这里直接使用eclipse自带的编辑工具),把对应的数据换成变量${xxx},使用Freemarker读取...
在Web应用中,有时需要按照固定的模板将数据导出到Word,如流程审批单,在流程处理完成后将处理过程按照流程单的要求导出,有时程序中需要实现生成标准Word文档,要求能够打印,并且保持页面样式不变,常见的方案有...
Java源代码实现部分,比较有意思,也具参考性。像坐标控制、旋转矩阵、定时器、生成图像、数据初始化、矩阵乘法、坐标旋转、判断是否是顺时针方向排列、鼠标按下、放开时的动作等,都可在本源码中得以体现。 Java...
Java源代码实现部分,比较有意思,也具参考性。像坐标控制、旋转矩阵、定时器、生成图像、数据初始化、矩阵乘法、坐标旋转、判断是否是顺时针方向排列、鼠标按下、放开时的动作等,都可在本源码中得以体现。 Java...
ftp4j是一个FTP客户端Java类库,实现了FTP客户端应具有的大部分功能文件(包括上传和下 载),浏览远程FTP服务器上的目录和文件,创建、删除、重命,移动远程目录和文件。ftp4j提供多种方式连接到远程FTP服务器包括...
ftp4j是一个FTP客户端Java类库,实现了FTP客户端应具有的大部分功能文件(包括上传和下 载),浏览远程FTP服务器上的目录和文件,创建、删除、重命,移动远程目录和文件。ftp4j提供多种方式连接到远程FTP服务器包括...
ftp4j是一个FTP客户端Java类库,实现了FTP客户端应具有的大部分功能文件(包括上传和下 载),浏览远程FTP服务器上的目录和文件,创建、删除、重命,移动远程目录和文件。ftp4j提供多种方式连接到远程FTP服务器包括...
ftp4j是一个FTP客户端Java类库,实现了FTP客户端应具有的大部分功能文件(包括上传和下 载),浏览远程FTP服务器上的目录和文件,创建、删除、重命,移动远程目录和文件。ftp4j提供多种方式连接到远程FTP服务器包括...
在生成PDF文档或word文档过程中,会用到系统字体,但生成文档会很大,想只调用我想要的字体,这样就极大的缩减了文档大小。
ftp4j是一个FTP客户端Java类库,实现了FTP客户端应具有的大部分功能文件(包括上传和下 载),浏览远程FTP服务器上的目录和文件,创建、删除、重命,移动远程目录和文件。ftp4j提供多种方式连接到远程FTP服务器包括...
ftp4j是一个FTP客户端Java类库,实现了FTP客户端应具有的大部分功能文件(包括上传和下 载),浏览远程FTP服务器上的目录和文件,创建、删除、重命,移动远程目录和文件。ftp4j提供多种方式连接到远程FTP服务器包括...
ftp4j是一个FTP客户端Java类库,实现了FTP客户端应具有的大部分功能文件(包括上传和下 载),浏览远程FTP服务器上的目录和文件,创建、删除、重命,移动远程目录和文件。ftp4j提供多种方式连接到远程FTP服务器包括...
ftp4j是一个FTP客户端Java类库,实现了FTP客户端应具有的大部分功能文件(包括上传和下 载),浏览远程FTP服务器上的目录和文件,创建、删除、重命,移动远程目录和文件。ftp4j提供多种方式连接到远程FTP服务器包括...
ftp4j是一个FTP客户端Java类库,实现了FTP客户端应具有的大部分功能文件(包括上传和下 载),浏览远程FTP服务器上的目录和文件,创建、删除、重命,移动远程目录和文件。ftp4j提供多种方式连接到远程FTP服务器包括...
ftp4j是一个FTP客户端Java类库,实现了FTP客户端应具有的大部分功能文件(包括上传和下 载),浏览远程FTP服务器上的目录和文件,创建、删除、重命,移动远程目录和文件。ftp4j提供多种方式连接到远程FTP服务器包括...