ASP.NET使用点聚WebOffice实现文档在线浏览

前段时间应导师要求,把他的那一堆堆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控件。最后看看那效果。

效果图

 

posted on 2012-05-30 01:30  疯子123  阅读(543)  评论(0编辑  收藏  举报

导航