PageOffice实现最简单的Java导出Word中的数据

普通的MS Office Word只能在本地磁盘上打开和编辑保存,这使得程序员在开发项目时受到很多的约束,许多的功能无法实现或者无法达到理想的效果。但是通过调用PageOffice开发平台,不仅可以在线打开并保存Word文件还可以提交Word中的数据。

下面我就简单的和大家分享一下如何实现Word文档的在线打开、编辑、保存和数据的提交。

第一步:拷贝文件到WEB项目的“WEB-INF/lib”目录下。拷贝PageOffice示例中下的“WEB-INF/lib”路径中的pageoffice.cabpageoffice.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 系统的程序员的一大技术难题。

 

你可能感兴趣的:(配置文件,本地磁盘,开发平台)