`

dsoframer.ocx 实现在线的word编辑

阅读更多

关于 dsoframer.ocx 的资料和API 我这里就不多说了。。百度 google 有很多

 

但是都是简单的介绍api 对于刚刚接触的人还是很难入手的。

 

所以我这里主要讲下如何来具体的使用,分享给大家,希望对大家帮助啊:

 

经过几天的研究,嘎嘎。。战果如下:

 


 

 

 

这里说明下 各个文件

dsoframer.ocx

大家都认识吧,微软提供的

 

dsoframer.js

封装了对 dsoframer.ocx 的操作

 

dsoframer.jsp

显示word的业务界面

 

dsoframer.CAB

 

这个是重头戏啊,引用这个文件,

可以在让 dsoframer.ocx 在浏览器中自动下载并注册 当初可弄了老半天的)

 

至于如何签名自己的 ocx,使其下载并注册,网页也有很多资料。

 

我这里也提供一个:http://blog.csdn.net/xjzdr/article/details/5991585 

 

流程都好看。最要命的是 里面的 inf 安装文件别写错了,否则就安装失败了,所以要千万记着。

这里偷偷的告诉你们一个秘密: 我是把别人公司的 CAB 安装解压,让回一步一步的模仿写出来的。。嘎嘎

具体是哪个公司,嘿嘿,,不好说。。秘密!  你们可以拷贝我的就好了啊。。

 

还有一点就是要注意  写版本 FileVersion=2,0,0,0  的时候 是逗号而不是点,不然报错!

 

下面看具体代码 

 

dsoframer.jsp  界面:

<%@ page language="java" pageEncoding="UTF-8" contentType="text/html; charset=UTF-8" %>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
String id = "1";
%>
<html>
	<head>
		<title>调查报告</title>
		<script language="javascript" src="dsoframer.js"></script>
		<script type="text/javascript">
			/*用法说明:
			  1,创建 word对象
			  2,设置文件上传url
			  3,在页面加载时,打开word文档,根据是否传人docUrl参数,决定是本地新建,还是从服务器端获取
			  4,在页面关闭时,执行上传操作。
			*/
             var word = new word();
             //决定路径
		     word.setUploadUrl("http://127.0.0.1:8070/word/upload_handle.jsp");
		     
		     var docurl = "";
		     function load(){
		         //方法:openDoc(docName, docUrl)
		         // docName:必填,本地保存的文件名, 也为上传到服务器上时的文件名
		         // docUrl: 填时,为从服务器端获取doc文档的路径, 不填时,表示本地新建doc文档 
		         
		         word.openDoc('1.doc',"http://127.0.0.1:8070/word/upload/1.doc");
		         
		         /**
		          //这里实现读取服务器的模板,并保存到服务器的业务路径中
		         $.post("/ZsytpServlet",{type:"ajaxWord",id:<%=id%>},function(result){
		 			  	var dataObj=eval("("+result+")");//转换为json对象 
		 			  	
		 			  	docurl = dataObj.docurl;
						if(docurl == ""){
							word.openDoc('<%=id%>.doc',"<%=basePath%>/webapps/zsytp/templ/"+dataObj.fhtk+".doc");
						
							document.getElementById('oframe').SetFieldValue("f_name",dataObj.f_name,"");
							document.getElementById('oframe').SetFieldValue("m_name",dataObj.m_name,"");
							document.getElementById('oframe').SetFieldValue("town",dataObj.town,"");
							document.getElementById('oframe').SetFieldValue("f_name1",dataObj.f_name,"");
							document.getElementById('oframe').SetFieldValue("m_name1",dataObj.m_name,"");
							document.getElementById('oframe').SetFieldValue("sqsj",dataObj.sqsj,"");
							document.getElementById('oframe').SetFieldValue("f_name2",dataObj.f_name,"");
							document.getElementById('oframe').SetFieldValue("f_birthday",dataObj.f_birthday,"");
							document.getElementById('oframe').SetFieldValue("f_hjdz",dataObj.f_hjdz,"");
							document.getElementById('oframe').SetFieldValue("m_name2",dataObj.m_name,"");
							document.getElementById('oframe').SetFieldValue("m_birthday",dataObj.m_birthday,"");
							document.getElementById('oframe').SetFieldValue("m_hjdz",dataObj.m_hjdz,"");
						}else{
						//实现读取业务路径的内容,并修改
							word.openDoc('<%=id%>.doc',"<%=basePath%>/webapps/zsytp/word/"+docurl);
						}		
			 	 });
			 	 **/
		         
		     }
		     
		     //为了简化,我定义关闭窗口的时候,保存到服务器上面,并且删除本地的临时文件
		     function unload(){
		         word.saveDoc();
		         word.close();
		     }
		     
		     //给书签赋值
		     function setFileVal(){
		     	document.getElementById('oframe').SetFieldValue("dm","2006-03-16 22:22:22","");
		     }
		     
		     //插入红头文件
		     
		     //等等。。网上都有 API
		     
		      
		     //真正开发的时候,,需要用到的方法,保存文件到服务器上
		     //可以查看里面的 document.getElementById('oframe').HttpAddPostString("id",id); 等向后台穿参数
		     function uploadFile(){
		     	//word.saveDocAndParm('1',docurl);
		     }
		</script>
	</head>
	<body onload="load();" onunload="unload();">  
	   <input  type="button" value="保存文件到服务器" onclick="uploadFile()" >
	   <hr/>
       <!-- 
       <object classid="clsid:00460182-9E5E-11d5-B7C8-B8269041DD57" codebase="dsoframer.ocx" id="oframe" width="100%" height="100%">
         <param name="BorderStyle" value="1">
         <param name="TitlebarColor" value="52479">
         <param name="TitlebarTextColor" value="0">  
       </object>
      -->
      <object classid="clsid:00460182-9E5E-11d5-B7C8-B8269041DD57" codebase="dsoframer.CAB#Version=2.0.0.0" id="oframe" width="100%" height="100%">
	         <param name="BorderStyle" value="1">
	         <param name="TitlebarColor" value="52479">
	         <param name="TitlebarTextColor" value="0">
       </object> 
	</body>
</html>

 

  
 upload_handle.jsp 上传的业务代码。。可以自己修改吧。。嘎嘎

 

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8" contentType="text/html; charset=UTF-8"%>
<%@page import="org.apache.commons.fileupload.servlet.ServletFileUpload"%>
<%@page import="org.apache.commons.fileupload.disk.DiskFileItemFactory"%>
<%@page import="java.io.File"%>
<%@page import="org.apache.commons.fileupload.FileItem"%>
<%@page import="java.text.SimpleDateFormat"%>
<%@page import="java.io.BufferedInputStream"%>
<%@page import="java.io.BufferedOutputStream"%>
<%@page import="java.io.FileOutputStream"%>
<%@page import="org.apache.commons.fileupload.util.Streams"%>
<%
	try{
		// 解析 request,判断是否有上传文件   
		boolean isMultipart = ServletFileUpload.isMultipartContent(request);
		System.out.println("---------"+isMultipart);
		if (isMultipart) {
	
			Date date = new Date();//获取当前时间
			SimpleDateFormat sdfFolder = new SimpleDateFormat("yyMM");
			String fileRealPath = "";//文件存放真实地址
			
			String fileRealResistPath = "";//文件存放真实相对路径
			String id="1";//id
			String docUrl=""; //路径
			String firstFileName="";
			
			String yyMM = sdfFolder.format(date);
			
			//上传文件夹绝对路径
			String physicsPath = request.getRealPath("")
					+ "\\upload\\" + yyMM + "\\";
	
			File file = new File(physicsPath);
			if (!file.isDirectory()) {
				file.mkdir();
			}
	
			// 创建磁盘工厂,利用构造器实现内存数据储存量和临时储存路径 
			DiskFileItemFactory factory = new DiskFileItemFactory();
			// 设置最多只允许在内存中存储的数据,单位:字节   
			// factory.setSizeThreshold(4096);   
			// 设置文件临时存储路径   
			// factory.setRepository(new File("D:\\Temp"));   
			// 产生一新的文件上传处理程式   
			ServletFileUpload upload = new ServletFileUpload(factory);
			// 设置路径、文件名的字符集   
			upload.setHeaderEncoding("UTF-8");
			// 设置允许用户上传文件大小,单位:字节   
			upload.setSizeMax(-1);
			//upload.setSizeMax(1024 * 1024);
			// 解析请求,开始读取数据   
			// Iterator<FileItem> iter = (Iterator<FileItem>) upload.getItemIterator(request);   
			// 得到所有的表单域,它们目前都被当作FileItem  
			BufferedInputStream in = null;
			List fileItems = upload.parseRequest(request);
			// 依次处理请求   
			Iterator iter = fileItems.iterator();
			while (iter.hasNext()) {
				FileItem item = (FileItem) iter.next();
				if (item.isFormField()) {
					// 如果item是正常的表单域   
					String name = item.getFieldName();
					String value = item.getString("UTF-8");
					if(name.equals("id"))
						id=value;//附件标题赋值
					else if(name.equals("docUrl"))
						docUrl=value;//附件ID赋值
				} else {
					// 如果item是文件上传表单域   
					// 获得文件名及路径   
					String fileName = item.getName();
					if (fileName != null) {
						firstFileName=item.getName().substring(item.getName().lastIndexOf("\\")+1);
						in = new BufferedInputStream(item.getInputStream());// 获得文件输入流
					}
				}
			}
			String formatName = firstFileName.substring(firstFileName.lastIndexOf("."));//获取文件后缀名	
			if(docUrl != null && !"".equals(docUrl.trim())){
				fileRealPath = request.getRealPath("") + "\\word\\" + docUrl;//文件存放真实地址
			}else{
				fileRealPath = physicsPath + id+ formatName;//文件存放真实地址
				docUrl = yyMM + "/" + id + formatName;
			}
			BufferedOutputStream outStream = new BufferedOutputStream(new FileOutputStream(new File(fileRealPath)));// 获得文件输出流
			Streams.copy(in, outStream, true);// 开始把文件写到你指定的上传文件夹			
	 
			//上传成功,则插入数据库
			if (new File(fileRealPath).exists()) {
				//虚拟路径赋值
				fileRealResistPath=sdfFolder.format(date)+"/"+fileRealPath.substring(fileRealPath.lastIndexOf("\\")+1);
				//DB db=new DB();
				//System.out.println("!!!"+(String) session.getAttribute("fpsssn")+"&&"+v07.can.myname(session));
				//int count = db.executeUpdate("update   zy_zsytp  set  docurl ='"+docUrl+"'  where  id ='"+id+"'");
				//if(count>0){
				//	response.setContentType("text/html;charset=UTF-8");
				//	out.print("<script>alert('上传成功!');</script>");
				//}
				//db.destroy();
				
				//保存到数据库
			}
		}
	}catch(Exception e){
		e.printStackTrace();
		//response.setContentType("text/html;charset=UTF-8");
		//out.print("<script>window.alert('上传失败!文件大小超过1MB!');</script>");
	}
	
%>

 

效果图:



 

 

哈哈。。下面就是  demo 咯。。。

 

本人的是 word 2003 。。至于 2007 我没测试过啊。。。你们看着办办。。。。

 

  • 大小: 27.9 KB
  • 大小: 81.9 KB
分享到:
评论
19 楼 wxfcgzht 2016-04-26  
   
qq_26333595 写道
我下载部署运行后提示:
1、TypeError: word.saveDoc is not a function
2、ReferenceError: ActiveXObject is not defined
   fso = new ActiveXObject("Scripting.FileSystemObject");
3、TypeError: word.openDoc is not a function
   word.openDoc('1.doc',"http://localhost:8080/word/upload/1.doc");

到家都没有遇到过这个问题吗  

    
遇到了,请问你是怎么解决的?谁知道给说下。
18 楼 qq_26333595 2016-03-31  
我下载部署运行后提示:
1、TypeError: word.saveDoc is not a function
2、ReferenceError: ActiveXObject is not defined
   fso = new ActiveXObject("Scripting.FileSystemObject");
3、TypeError: word.openDoc is not a function
   word.openDoc('1.doc',"http://localhost:8080/word/upload/1.doc");

到家都没有遇到过这个问题吗  
17 楼 jatqiq 2015-11-25  
楼主,问一下,现在这个dsoframer.ocx支持office 2010吗?有没有最新版了??急需。
16 楼 yangpanwww 2015-11-03  
kakarottoz 写道
楼主有个问题请教下,使用dsoframer.ocx必须要求本机安装有office word吗?


服务器 必须安装。。本机不需要。。。
15 楼 kakarottoz 2015-10-19  
楼主有个问题请教下,使用dsoframer.ocx必须要求本机安装有office word吗?
14 楼 u010702861 2015-08-06  
楼主你好,你的这个demo中的“保存文件到服务器”的功能可以用吗?
13 楼 cl13142006 2014-06-20  
下载完之后,在新创建区域写值,上传磁盘是对的,上传服务器为0kb
12 楼 nitaishan 2014-01-12  
先下载来试一下。
11 楼 yangpanwww 2013-12-27  
itoao 写道
请问一下楼主,这浏览器访问的时候安装不上啊,是不是还要再弄一个证书啊?


不需要的,已经弄成 cba 包,可以自动下载安装的....如果不可以,你先手动注册试试看
10 楼 itoao 2013-12-25  
请问一下楼主,这浏览器访问的时候安装不上啊,是不是还要再弄一个证书啊?
9 楼 lghjbxc 2013-07-01  
楼主。那个dsoframer.js怎么不起作用的,写法应该也不对,你确定你的项目能跑起来?
8 楼 hufangxian 2013-06-06  

} else {
// 如果item是文件上传表单域  
// 获得文件名及路径  
String fileName = item.getName();
if (fileName != null) {
firstFileName=item.getName().substring(item.getName().lastIndexOf("\\")+1);
in = new BufferedInputStream(item.getInputStream());// 获得文件输入流
}
}         
}

我的问题在于最后获取的文件输入流中没有数据。

我的操作系统是win7旗舰版
7 楼 yangpanwww 2013-06-06  
hufangxian 写道
while (iter.hasNext()) {
num++;
System.out.println("num:"+num);
FileItem item = (FileItem) iter.next();
if (item.isFormField()) {
// 如果item是正常的表单域  
String name = item.getFieldName();
String value = item.getString("UTF-8");
if(name.equals("id")){
id=value;//附件标题赋值

}

else if(name.equals("docUrl")){
docUrl=value;//附件ID赋值

}

} else {
// 如果item是文件上传表单域  
// 获得文件名及路径  
String fileName = item.getName();
if (fileName != null) {
firstFileName=item.getName().substring(item.getName().lastIndexOf("\\")+1);
in = new BufferedInputStream(item.getInputStream());// 获得文件输入流
}
}         
}

我的问题在于最后获取的文件输入流中没有数据。



看看你的操作系统,如果是普通的PC XP 系统,应该是可以的。。如果是service系统。。是传不上去的。。。具体原因也没弄清楚我。。。
6 楼 hufangxian 2013-06-04  
while (iter.hasNext()) {
num++;
System.out.println("num:"+num);
FileItem item = (FileItem) iter.next();
if (item.isFormField()) {
// 如果item是正常的表单域  
String name = item.getFieldName();
String value = item.getString("UTF-8");
if(name.equals("id")){
id=value;//附件标题赋值

}

else if(name.equals("docUrl")){
docUrl=value;//附件ID赋值

}

} else {
// 如果item是文件上传表单域  
// 获得文件名及路径  
String fileName = item.getName();
if (fileName != null) {
firstFileName=item.getName().substring(item.getName().lastIndexOf("\\")+1);
in = new BufferedInputStream(item.getInputStream());// 获得文件输入流
}
}         
}

我的问题在于最后获取的文件输入流中没有数据。
5 楼 yangpanwww 2013-05-24  
cenjun615 写道
请问,我修改服务器上文件,保存后,参数传递不到后台是怎么问题,request中没有值,ServletFileUpload.isMultipartContent(request) 也为false



嗯。。如果你的服务器的操作系统 是 service 版本的。。好像是不行..普通的PC XP 系统好像是可以。。。这个我也发现过。。没找出问题所在。。也许是服务器的操作系统的安全策略比较高吧。。。
4 楼 cenjun615 2013-05-22  
请问,我修改服务器上文件,保存后,参数传递不到后台是怎么问题,request中没有值,ServletFileUpload.isMultipartContent(request) 也为false
3 楼 yangpanwww 2013-03-30  
liulangdeyu999 写道
楼主,那个dsoframer.js怎么不起作用, 要是把js写到dsoframer.jsp页面中就好用了,这个是什么情况



  

估计是你的自动注册失败了。。要不你手动注册下
2 楼 liulangdeyu999 2013-02-28  
楼主,那个dsoframer.js怎么不起作用, 要是把js写到dsoframer.jsp页面中就好用了,这个是什么情况
1 楼 liulangdeyu999 2013-02-27  
楼主,我这个程序运行起来 什么也没看到啊,什么情况

相关推荐

    dsoframer.ocx控件

    DSOFramer.ocx 是一个非常实用的 ActiveX 控件,主要用于在 Web 应用程序中实现在线编辑 Office 文档的功能。它允许用户在浏览器环境中内嵌 Office 办公软件,如 Word、Excel 和 PowerPoint,提供了一种无缝集成的...

    dsoframer.ocx 2.3.0.2版本

    1. **嵌入文档**:DSOFramer.ocx可以将Word或Excel文档嵌入到应用程序的窗体中,让用户在应用程序内部查看和编辑文档,而无需启动单独的Office应用。 2. **文档操作**:开发者可以通过API调用来控制文档的行为,...

    dsoframer.ocx控件最新版支持office2016

    **DSOFramer.ocx控件** 是一个专为软件开发者设计的组件,它主要用于在Windows Forms(WinForm)应用程序中嵌入Office文档,如Word、Excel等。此控件的最新版已经更新以支持Microsoft Office 2016,这意味着开发者...

    DsoFramer.ocx接口及说明

    word在线编辑,加密,书签,等2. HRESULT Open([in] VARIANT Document, [in, optional] VARIANT ReadOnly, [in, optional] VARIANT ProgId, [in, optional] VARIANT WebUsername, [in, optional] VARIANT ...

    dsoframer.ocx_DsoFramer_

    DsoFramer.ocx是一个OCX文件,即OLE控件,主要用于在应用程序中嵌入和控制Microsoft Office文档,比如Word、Excel或PowerPoint。 【描述】"DsoFramer_V1.3此为最新版源码,修正了对OFFICE2010的支持。" 这段描述...

    dsoframer.ocx 完整资料

    通过结合dsoframer.ocx,开发者可以在ASP.NET页面上实现Office文档的在线预览和编辑,提升用户体验。 **dsoframer.cab** 文件通常包含dsoframer.ocx组件的安装包,它是 cabinet 文件格式,用于存储和分发软件组件。...

    DSOFRAMER.OCX

    总结起来,DSOFRAMER.OCX是一个强大的OCX控件,为开发者提供了一种便捷的方式来在应用程序中集成Word和Excel文档的查看和编辑功能,无需依赖完整的Microsoft Office环境。它的应用范围广泛,从简单的文档预览到复杂...

    DSOFramer.ocx 打开word ppt

    - DSOFramer.ocx 是由Microsoft提供的一种ActiveX组件,它为开发人员提供了一个接口,可以将Word、Excel等Office应用程序的界面嵌入到自定义的应用程序中,实现文档的查看、编辑和打印等功能。 - 通过DSOFramer...

    dsoframer.ocx源码与列子

    【dsoframer.ocx】是微软开发的一个ActiveX控件,主要用于在Web应用程序中实现对Word、Excel和PowerPoint文档的在线编辑功能。ActiveX技术是微软在Internet Explorer浏览器中引入的一种组件模型,允许开发者集成各种...

    DSOFramer.ocx 源码

    1. **嵌入Office文档**:通过DSOFramer控件,开发者可以在一个窗体或者对话框中直接嵌入Word、Excel、PowerPoint等Office文档,提供无缝的用户体验,用户可以直接在应用程序内部查看和编辑这些文档,无需打开单独的...

    dsoFramer_Source_1.3.zip_1.3_DsoFramer_dsoframer.ocx 1.3_source_

    在实际应用中,DSOFramer控件可以广泛应用于各种需要集成Word功能的场景,如报表生成、文档编辑器、在线文档预览等。开发者只需要调用相应的API,就可以轻松地在自己的应用程序中实现Word文档的各种操作,极大地提高...

    dsoframer.ocx.7z

    dsoframer.ocx是一款强大的ActiveX控件,它允许开发者在应用程序中嵌入Microsoft Office文档,如Word、Excel或PowerPoint等,实现对Office文档的动态显示和交互操作。在本次讨论中,我们将聚焦于dsoframer.ocx 2.3....

    dsoframer.ocx 接口

    总之,DSOFramer.ocx接口提供了丰富的功能,使开发人员能够轻松地在网页上集成Office文档处理,创建互动的Web应用,尤其适用于需要在线协作编辑、审批文档的场景。然而,由于ActiveX的安全性和浏览器兼容性问题,...

    DSOFramer.ocx 控件使用

    DSOFramer.ocx 控件主要用于集成在线编辑功能,支持Word与Excel等文件类型的处理。该控件提供了丰富的API接口,可实现文件的新建、打开、保存以及一系列高级功能如修订留痕、设置用户信息等操作。 #### 二、主要...

    dsoframer2.3.ocx.rar

    《DSOFramer在线Word编辑控件详解》 DSOFramer是一款功能强大的ActiveX控件,主要应用于嵌入式在线Word编辑。它允许开发者在桌面软件和Web网页中集成Word编辑功能,极大地提升了用户在非Microsoft Office环境下编辑...

    dsoframer.ocx 2.3.0.0(源码,支持Office2007)

    1. 支持Office2007:dsoframer.ocx能够无缝对接Microsoft Office 2007的文档格式,包括Word、Excel、PowerPoint等,用户无需离开网页即可编辑这些文档,极大地提升了工作效率。 2. 在线编辑功能:控件提供丰富的...

    DSOFramer.ocx_帮助文档.doc

    使用 DSOFramer.ocx 控件,开发者可以轻松地集成 Office 功能到自己的应用程序中,例如,在 Web 应用程序中嵌入 Excel 表格或 Word 文档编辑功能,提高应用的灵活性和用户友好度。此外,通过对 Dispatch 接口的操作...

    dsoframer.ocx

    DSOFramer.ocx是一款免费且易用的Web在线Office编辑控件,尤其适用于需要在网页中实现Word和Excel文档编辑的应用场景。该控件提供了丰富的接口,允许开发者进行文档的新建、打开、设置属性等操作,极大地提升了网页...

    dsoframer.ocx 开发控件

    dsoframer.ocx 控件为程序员提供了强大的文档呈现能力,可以方便地在应用程序中嵌入和打印各种类型的文档,如PDF、Word、Excel等。 **主要功能** 1. **文档查看**:dsoframer.ocx 可以加载并显示多种格式的文档,...

Global site tag (gtag.js) - Google Analytics