前段时间应导师要求,把他的那一堆堆word文档分类整理,并在此基础上做一个基于B/S的文件管理系统,并能实现查找浏览,文件管理系统问题不大,问题是怎把那一堆堆word文档给展示出来,上千个word文档我不可能一个个把里面的内容都录入数据库,况且word文档里面有些还有图什么的,怎么办呢?想来想去,最后想到了WebOffice这个东东,经过不懈努力最后终于弄好了,在此和大家分享一下!
首先我选用的是点聚的WebOffice V6.0.4.4(主要是体积小点),最新的是V6.0.5.0(发布日期2010-07-17),下载地址:http://www.dianju.cn/forum/viewtopic.php?f=2&t=2#p2,下载其中的一个示例,比如HTML例子,里面就有weboffice_v6.0.5.0.cab这个包,要用到的就是他里面的WebOffice.ocx这个东西,官网上还有一个pdf的开发文档,大家可以看看,但是我本人由于时间比较紧迫,加上本人一看javascript就头疼,我就简单实现了我想要的功能:用这个WebOffice打开我指定的word文档,其他的我就不深入研究了,各位有需要可以自行研究。
废话少说,在你的Web应用程序里新建一个web窗体,比如openFile.aspx,其中openFile.aspx代码很简单如下:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="openFile.aspx.cs" Inherits="openFile" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <title>CICCPS</title> <script language="javascript" type="text/javascript"> //WebOffice1_NotifyCtrlReady(); function openDoc() { var fid='<%=fid %>'; //alert("/Files.aspx?fid="+fid); //加载控件 document.all.WebOffice.LoadOriginalFile("/Files.aspx?fid="+fid, "doc"); //隐藏不需要的按钮 document.all.WebOffice.HideMenuItem(0x01 + 0x02 + 0x04 + 0x10 + 0x20); } function WebOpen() { obj = document.all.item("WebOffice"); if (obj !='') { //等待控件初始化完毕,时间长短可以根据网络速度设定。 setTimeout('openDoc()',100); } } </script> </head> <body onload="javascript:WebOpen();"> <form id="form1" runat="server"> <div> <object id="WebOffice" height="768" width='100%' style='left: 0px; top: 0px' classid='clsid:E77E049B-23FC-4DB8-B756-60529A35FAD5' codebase='/weboffice/WebOffice.ocx'> <param name='_ExtentX' value='6350'> <param name='_ExtentY' value='6350'> </object> </div> </form> </body> </html>
这里主要说两点,第一点是document.all.WebOffice.LoadOriginalFile("/Files.aspx?fid="+fid, "doc");这个脚本,这个LoadOriginalFile()函数入口参数有两个,第一个是word文件在服务器端的地址,说简单点就是你只要能保证"/Files.aspx?fid="+fid能下载到对应的文件就行,第二个参数当然就是文件类型了;第二点是这段脚本
<object id="WebOffice" height="768" width='100%' style='left: 0px; top: 0px' classid='clsid:E77E049B-23FC-4DB8-B756-60529A35FAD5' codebase='/weboffice/WebOffice.ocx'> <param name='_ExtentX' value='6350'> <param name='_ExtentY' value='6350'> </object>
它的意思是:自动更新classid= E77E049B-23FC-4DB8-B756-60529A35FAD5的COM组件, 更新地址为/weboffice/WebOffice.ocx,codebase后的路径为相对路径也可为绝对路径,要更新的最新版本为6.0.4.4。此时,IE会自动访问注册表,如果发现当前机器未安装或者当前版本低于6.0.4.4,就会自动下载。
至于openFile.aspx.cs的代码就更简单,主要是实现fid的数值绑定,当然你也可以在前面用js脚本直接取fid,但是我这边还得验证这个文件编号,所以就写在了后面。
public string fid = "1"; protected void Page_Load(object sender, EventArgs e) { fid = Request["fid"].ToString(); Page.DataBind(); }
这样就能在线打开word文件啦,最后顺便提一下WebOffice工作原理,所谓的在线打开word文档,其实WebOffice是先把你要打开的文件下载回你本机的临时目录,再调用你本地机器上的office来打开,也就是说如果你机器上没有Office的话,那么WebOffice也是无能为力的。另外每台客户端机器第一次打开文件时都要下载那个WebOffice.ocx回本地C:\WINDOWS\system32目录,所以浏览器必须允许阻止的内容被打开,这样系统才会自动下载安装weboffice控件。最后看看那效果。