PageOffice实现最简单的Java导出Word中的数据
2013-05-24 10:09
453 查看
普通的MS Office Word只能在本地磁盘上打开和编辑保存,这使得程序员在开发项目时受到很多的约束,许多的功能无法实现或者无法达到理想的效果。但是通过调用PageOffice开发平台,不仅可以在线打开并保存Word文件还可以提交Word中的数据。下面我就简单的和大家分享一下如何实现Word文档的在线打开、编辑、保存和数据的提交。第一步:拷贝文件到WEB项目的“WEB-INF/lib”目录下。拷贝PageOffice示例中下的“WEB-INF/lib”路径中的pageoffice.cab和pageoffice.jar到新建项目的“WEB-INF/lib”目录下。第二步:修改WEB项目的配置文件。将如下代码添加到配置文件中:<!-- PageOffice Begin -->
<servlet>
<servlet-name>poserver</servlet-name><servlet-class>com.zhuozhengsoft.pageoffice.poserver.Server</servlet-class></servlet>
<servlet-mapping>
<servlet-name>poserver</servlet-name>
<url-pattern>/poserver.do</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>poserver</servlet-name>
<url-pattern>/pageoffice.cab</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>poserver</servlet-name>
<url-pattern>/popdf.cab</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>poserver</servlet-name>
<url-pattern>/sealsetup.exe</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>adminseal</servlet-name>
<servlet-class>com.zhuozhengsoft.pageoffice.poserver.AdminSeal</servlet-class></servlet>
<servlet-mapping>
<servlet-name>adminseal</servlet-name>
<url-pattern>/adminseal.do</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>adminseal</servlet-name>
<url-pattern>/loginseal.do</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>adminseal</servlet-name>
<url-pattern>/sealimage.do</url-pattern>
</servlet-mapping>
<mime-mapping>
<extension>mht</extension>
<mime-type>message/rfc822</mime-type>
</mime-mapping>
<context-param>
<param-name>adminseal-password</param-name>
<param-value>123456</param-value>
</context-param>
<!-- PageOffice End -->
第三步:添加引用。在WEB项目的WebRoot目录下添加动态页面Word.jsp。在该页面后台代码中添加自定义标签库:“<%@ taglib uri="http://java.pageoffice.cn" prefix="po"%>”引入PageOffice类库:“<%@page import=” com.zhuozhengsoft.pageoffice.*,com.zhuozhengsoft.pageoffice.wordwriter.*”%>”。在HTML的<body>中添加PageOffice引用:“<po:PageOfficeCtrlid="PageOfficeCtrl1"></po:PageOfficeCtrl>”,并设置控件所在层(<div></div>)的高和宽。第四步:在要打开的Word文件中的相应位置手动插入书签(“PO_userName”、“PO_deptName”)。注意:书签名字不要重复、相邻书签之间至少要有一个字符,不然后一个书签会把前一个书签覆盖掉;书签的名字需以“PO_”为前缀。第五步:Word.jsp页面编写代码,打开Word文档。部分代码如下:PageOfficeCtrl poCtrl = new PageOfficeCtrl(request);//设置服务器页面
poCtrl.setServerPage("poserver.do");
WordDocument wordDoc = new WordDocument();
//打开数据区域,openDataRegion方法的参数代表Word文档中的书签名称
DataRegion dataRegion1 = wordDoc.openDataRegion("PO_userName");
//设置DataRegion的可编辑性
dataRegion1.setEditing(true);
//为DataRegion赋值,此处的值可在页面中打开Word文档后自己进行修改
dataRegion1.setValue("");
//设置字体颜色
dataRegion1.getFont().setColor(Color.RED);
DataRegion dataRegion2 = wordDoc.openDataRegion("PO_deptName");
dataRegion2.setEditing(true);
dataRegion2.setValue("");
dataRegion1.getFont().setColor(Color.RED);
poCtrl.setWriter(wordDoc);
//添加自定义按钮
poCtrl.addCustomToolButton("保存", "Save", 1);
//设置保存页面
poCtrl.setSaveDataPage("SaveData.jsp");
//打开Word文档
poCtrl.webOpen("doc/test.doc", OpenModeType.docSubmitForm, "张佚名");
poCtrl.setTagId("PageOfficeCtrl1");//此行必需说明:若想提交数据需将webOpen()方法的第二个参数OpenModeType的类型设置为docSubmitForm提交类型在HTML页面添加JS函数Save(),如下:function Save() {document.getElementById("PageOfficeCtrl1").WebSave();
}如上所述,简单的就实现了Word文档的在线打开并提交的操作。接下来开始编写保存页面。第六步:添加保存页面。在网站中添加动态页面SaveData.jsp,在后台页面中编写代码处理Word文档提交的数据,部分代码如下:WordDocument doc = new WordDocument(request, response);//获取提交的数值
DataRegion dataUserName = doc.openDataRegion("PO_userName");
DataRegion dataDeptName = doc.openDataRegion("PO_deptName");
doc.close();至此,就简单的实现了Word文档的在线打开、编辑、保存和提交数据了。方案总结:上述的示例主要是借助了PageOffice开发平台的PageOfficeCtrl控件,利用该控件还可实现Excel文档内容的提交、添加手写批注、加盖电子印章、Word文档到PDF文档的转换等功能。另外,在PageOffice平台下还可实现Excel、PPT、PDF等文档的在线打开、编辑保存等等各种操作,很好地解决了开发OA系统的程序员的一大技术难题。
<servlet>
<servlet-name>poserver</servlet-name><servlet-class>com.zhuozhengsoft.pageoffice.poserver.Server</servlet-class></servlet>
<servlet-mapping>
<servlet-name>poserver</servlet-name>
<url-pattern>/poserver.do</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>poserver</servlet-name>
<url-pattern>/pageoffice.cab</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>poserver</servlet-name>
<url-pattern>/popdf.cab</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>poserver</servlet-name>
<url-pattern>/sealsetup.exe</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>adminseal</servlet-name>
<servlet-class>com.zhuozhengsoft.pageoffice.poserver.AdminSeal</servlet-class></servlet>
<servlet-mapping>
<servlet-name>adminseal</servlet-name>
<url-pattern>/adminseal.do</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>adminseal</servlet-name>
<url-pattern>/loginseal.do</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>adminseal</servlet-name>
<url-pattern>/sealimage.do</url-pattern>
</servlet-mapping>
<mime-mapping>
<extension>mht</extension>
<mime-type>message/rfc822</mime-type>
</mime-mapping>
<context-param>
<param-name>adminseal-password</param-name>
<param-value>123456</param-value>
</context-param>
<!-- PageOffice End -->
第三步:添加引用。在WEB项目的WebRoot目录下添加动态页面Word.jsp。在该页面后台代码中添加自定义标签库:“<%@ taglib uri="http://java.pageoffice.cn" prefix="po"%>”引入PageOffice类库:“<%@page import=” com.zhuozhengsoft.pageoffice.*,com.zhuozhengsoft.pageoffice.wordwriter.*”%>”。在HTML的<body>中添加PageOffice引用:“<po:PageOfficeCtrlid="PageOfficeCtrl1"></po:PageOfficeCtrl>”,并设置控件所在层(<div></div>)的高和宽。第四步:在要打开的Word文件中的相应位置手动插入书签(“PO_userName”、“PO_deptName”)。注意:书签名字不要重复、相邻书签之间至少要有一个字符,不然后一个书签会把前一个书签覆盖掉;书签的名字需以“PO_”为前缀。第五步:Word.jsp页面编写代码,打开Word文档。部分代码如下:PageOfficeCtrl poCtrl = new PageOfficeCtrl(request);//设置服务器页面
poCtrl.setServerPage("poserver.do");
WordDocument wordDoc = new WordDocument();
//打开数据区域,openDataRegion方法的参数代表Word文档中的书签名称
DataRegion dataRegion1 = wordDoc.openDataRegion("PO_userName");
//设置DataRegion的可编辑性
dataRegion1.setEditing(true);
//为DataRegion赋值,此处的值可在页面中打开Word文档后自己进行修改
dataRegion1.setValue("");
//设置字体颜色
dataRegion1.getFont().setColor(Color.RED);
DataRegion dataRegion2 = wordDoc.openDataRegion("PO_deptName");
dataRegion2.setEditing(true);
dataRegion2.setValue("");
dataRegion1.getFont().setColor(Color.RED);
poCtrl.setWriter(wordDoc);
//添加自定义按钮
poCtrl.addCustomToolButton("保存", "Save", 1);
//设置保存页面
poCtrl.setSaveDataPage("SaveData.jsp");
//打开Word文档
poCtrl.webOpen("doc/test.doc", OpenModeType.docSubmitForm, "张佚名");
poCtrl.setTagId("PageOfficeCtrl1");//此行必需说明:若想提交数据需将webOpen()方法的第二个参数OpenModeType的类型设置为docSubmitForm提交类型在HTML页面添加JS函数Save(),如下:function Save() {document.getElementById("PageOfficeCtrl1").WebSave();
}如上所述,简单的就实现了Word文档的在线打开并提交的操作。接下来开始编写保存页面。第六步:添加保存页面。在网站中添加动态页面SaveData.jsp,在后台页面中编写代码处理Word文档提交的数据,部分代码如下:WordDocument doc = new WordDocument(request, response);//获取提交的数值
DataRegion dataUserName = doc.openDataRegion("PO_userName");
DataRegion dataDeptName = doc.openDataRegion("PO_deptName");
doc.close();至此,就简单的实现了Word文档的在线打开、编辑、保存和提交数据了。方案总结:上述的示例主要是借助了PageOffice开发平台的PageOfficeCtrl控件,利用该控件还可实现Excel文档内容的提交、添加手写批注、加盖电子印章、Word文档到PDF文档的转换等功能。另外,在PageOffice平台下还可实现Excel、PPT、PDF等文档的在线打开、编辑保存等等各种操作,很好地解决了开发OA系统的程序员的一大技术难题。
相关文章推荐
- 用PageOffice实现最简单的导出获取Excel中的数据
- java简单实现爬虫、jsoup实现网页抓取、POI实现数据导出Excel
- JAVA 数据导出Word文档模板的功能实现
- java实现把数据库数据导出成word文件实现文件下载功能
- java poi实现数据库数据导出到excel
- 利用Java实现简单的抓取网页数据并存放于plist中
- JAVA 将数据导出Word文档(经过测试)
- Java程序员从笨鸟到菜鸟之(一百零五)java操作office和pdf文件(三)利用jxl实现数据导出excel报表以及与POI的区别
- GridView简单实现导出数据到Excel
- java实现数据库数据导出到Excel并下载查看
- 在一个程序中需要用到全局变量(在多个class之间共享数据),请问如何定义具有这种功能的变量?或者是否有其他的方法解决多个class之间的数据共享(尽量简单实现)。 首先应该明确 Java中没有全局变
- java用freemarker导出数据到word(含多图片)
- 黑马 总结二:Java 数据连接池简单实现
- C#简单实现动态数据生成Word文档并保存
- 利用JavaScript 实现Word简单导出功能
- JAVA导出特殊表头数据-POI实现
- java中list数据拆分为sublist实现分页的简单代码
- Java使用POI实现数据导出excel报表
- java导出数据到word(二)
- Java 实现Excel导入导出(包含一些简单样式设置)工具类