dsoframer java_dsoframer介绍

展开全部

DSOFramer下载+开发接口(微软提供ole组件)

版本修改记录62616964757a686964616fe58685e5aeb931333239306637:

V2.2.0.2修改:

修改了HttpPost相对路径的一些问题。

V2.2.0.0增加:

[id(0x00010041), helpstring("Get Rev Index")]

HRESULT GetRevCount( [out,retval] long * pbool);

[id(0x00010042), helpstring("Get Rev Index Info")]

HRESULT GetRevInfo([in] long lIndex, [in] long lType, [out,retval] BSTR* pbool);

[id(0x00010043), helpstring("Set Doc Prop")]

HRESULT SetValue([in] BSTR strValue, [in] BSTR strName, [out,retval] long* pbool);

[id(0x00010044), helpstring("Set Doc Variable")]

HRESULT SetDocVariable([in] BSTR strVarName, [in] BSTR strValue,[in] long lOpt, [out,retval] long* pbool);

[id(0x00010045), helpstring("Save page To Doc")]

HRESULT SetPageAs([in] BSTR strLocalFile, [in] long lPageNum, [in] long lType,[out,retval] long* pbool);

----------------------------------------------------------------------------------------------------------------------------------------------------------------------

LoadDso.js

var s = ""

s += "

s += "classid=clsid:00460182-9E5E-11D5-B7C8-B8269041DD57 codeBase=DSOFramer.ocx#Version=2,2,0,0' >"

s += "

"

document.write(s)

----------------------------------------------------------------------------------------------------------------------------------------------------------------------

接口文档:

/*

1.新建

*/

//新建Word

document.all.FramerControl1.CreateNew("Word.Document");

//新建Excel

document.all.FramerControl1.CreateNew("Excel.Sheet");

/*

2.打开文件

*/

//打开制定的本地文件

document.all.FramerControl1.Open("C:\\TestBook.xls");

//制定用Word来打开c:\plain.txt文件

document.all.FramerControl1.Open("C:\\Plain.txt",false, "Word.Document");

//打开服务器的文件

document.all.FramerControl1.Open "https://secureserver/test/mytest.asp?id=123",true, "Excel.Sheet", "MyUserAccount", "MyPassword");

//打开服务器的文件

document.all.FramerControl1.Open("http://localhost/1.doc", true);

/*

3.保存文件

*/

//到本地

document.all.FramerControl1.Save("c:\\1.doc",true);

//服务器

/*增加Http协议Post上传接口,可以Post一个动态页面(jsp,asp,php...),由动态页面负责解析数据

bool HttpInit();

bool HttpAddPostString(BSTR strName, BSTR strValue);

bool HttpAddPostCurrFile(BSTR strFileID, BSTR strFileName);

BSTR HttpPost(BSTR bstr);

*/

//初始化Http引擎

document.all.FramerControl1.HttpInit();

//增加Post变量

document.all.FramerControl1.HttpAddPostString("RecordID","20060102200");

document.all.FramerControl1.HttpAddPostString("UserID","李局长");

//上传打开的文件

document.all.FramerControl1.HttpAddPostCurrFile("FileData", "文档名.doc");

//执行上传动作

document.all.FramerControl1.HttpPost("http://xxxx.com/uploadfile.asp");

/*

4.修订留痕

*/

//进入留痕状态

document.all.FramerControl1.SetTrackRevisions(1);

//进入非留痕状态

document.all.FramerControl1.SetTrackRevisions(0);

//接受当前修订

document.all.FramerControl1.SetTrackRevisions(4);

/*

5.设置当前用户

*/

document.all.FramerControl1.SetCurrUserName("张三");

/*

6.设置当前时间(笔迹留痕会显示("Like 2006:02:07 11:11:11")

*/

document.all.FramerControl1.SetCurrTime("2006:02:07 11:11:11");

/*

7.设置和创建书签,此功能比较强大,设置书签数据、添加书签和添加红头文件就靠他了

SetFieldValue(BSTR strFieldName, BSTR strValue, BSTR strCmdOrSheetName)

strFieldName:书签名

strValue:要设置的值

strCmdOrSheetName:

命令

::ADDMARK:: 添加BookMark

::DELMARK:: 删除这个BookMark

::GETMARK:: 定位到这个BookMark

::FILE:: 插入的是文件

::JPG:: 插入的是图片

一般来说:WORD中书签是做好的,可以通过此接口把外界数据设置进书签中去。

*/

//在当前WORD位置插入标签,标签名为"book1",数值为"test"

document.all.FramerControl1.SetFieldValue("book1","test","::ADDMARK::");

//设置书签"Time",数值为"2006-03-16 22:22:22"

document.all.FramerControl1.SetFieldValue("Time","2006-03-16 22:22:22","");

//在书签位置"hongtou",插入红头文件"http://222.222.222.222/hongtou1.doc" 这样,红头就自动插进去了

document.all.FramerControl1.SetFieldValue("hongtou","http://222.222.222.222/hongtou1.doc","::FILE::");

/*

8.设置菜单显示情况

BOOL SetMenuDisplay(long lMenuFlag)

lMenuFlag为以下数值的组合

#define MNU_NEW 0x01

#define MNU_OPEN 0x02

#define MNU_CLOSE 0x04

#define MNU_SAVE 0x08

#define MNU_SAVEAS 0x16

#define MNU_PGSETUP 0x64

#define MNU_PRINT 0x256

#define MNU_PROPS 0x32

#define MNU_PRINTPV 0x126

*/

//只有“新建”菜单可用

document.all.FramerControl1..SetMenuDisplay(1);

//只有“打开”菜单可用

document.all.FramerControl1.SetMenuDisplay(2);

//只有“打开”和“新建”菜单可用

document.all.FramerControl1.SetMenuDisplay(3);

/*

9.保护文档和解保护文档

lProOrUn:1:保护文档;0:解除保护

lProType:

wdNoProtection = -1,

wdAllowOnlyRevisions = 0,

wdAllowOnlyComments = 1,

wdAllowOnlyFormFields = 2

strProPWD:密码

*/

//完全保护文档,密码为"pwd"

document.all.FramerControl1.ProtectDoc(1,1,"pwd");

//解除文档保护

document.all.FramerControl1.ProtectDoc(0,1,"pwd");

/*

10.显示或隐藏修订内容

ShowRevisions(long nNewValue)

nNewValue = 0 则隐藏修订

= 1 则显示修订

*/

//显示修订留痕

document.all.FramerControl1.ShowRevisions(1);

//隐藏修订留痕

document.all.FramerControl1.ShowRevisions(0);

/*

11.插入合并文件,

strFieldPath 文件路径,可以是http,ftp的路径

pPos = 0 //当前鼠标位置

1;文件开头

2;文件末尾

pPos的第4位为1的时候,代表插入的是图片

InSertFile(BSTR strFieldPath, long lPos)

*/

//文件头部插入文件

document.all.FramerControl1.InSertFile("http://XX.com/XX.doc",1);

//文件尾部插入文件

document.all.FramerControl1.InSertFile("http://XX.com/XX.doc",2);

//当前光标位置插入文件

document.all.FramerControl1.InSertFile("http://XX.com/XX.doc",0);

//文件头部插入图片

document.all.FramerControl1.InSertFile("http://XX.com/XX.jpg",9);

//文件尾部插入图片

document.all.FramerControl1.InSertFile("http://XX.com/XX.jpg",10);

//当前光标位置插入图片

document.all.FramerControl1.InSertFile("http://XX.com/XX.jpg",8);

/*

0x31. 文档另存为

HRESULT SaveAs([in] VARIANT strFileName, [in] VARIANT dwFileFormat, [out,retval] long* pbool);

参数:

strFileName:文件本地路径,如c:\\11.doc

dwFileFormat: 文件格式

dwFileFormat的数值为:

Excel: Type

enum XlFileFormat

{

xlAddIn = 18,

xlCSV = 6,

xlCSVMac = 22,

xlCSVMSDOS = 24,

xlCSVWindows = 23,

xlDBF2 = 7,

xlDBF3 = 8,

xlDBF4 = 11,

xlDIF = 9,

xlExcel2 = 16,

xlExcel2FarEast = 27,

xlExcel3 = 29,

xlExcel4 = 33,

xlExcel5 = 39,

xlExcel7 = 39,

xlExcel9795 = 43,

xlExcel4Workbook = 35,

xlIntlAddIn = 26,

xlIntlMacro = 25,

xlWorkbookNormal = -4143,

xlSYLK = 2,

xlTemplate = 17,

xlCurrentPlatformText = -4158,

xlTextMac = 19,

xlTextMSDOS = 21,

xlTextPrinter = 36,

xlTextWindows = 20,

xlWJ2WD1 = 14,

xlWK1 = 5,

xlWK1ALL = 31,

xlWK1FMT = 30,

xlWK3 = 15,

xlWK4 = 38,

xlWK3FM3 = 32,

xlWKS = 4,

xlWorks2FarEast = 28,

xlWQ1 = 34,

xlWJ3 = 40,

xlWJ3FJ3 = 41,

xlUnicodeText = 42,

xlHtml = 44

};

Word: Type

enum WdSaveFormat

{

wdFormatDocument = 0,

wdFormatTemplate = 1,

wdFormatText = 2,

wdFormatTextLineBreaks = 3,

wdFormatDOSText = 4,

wdFormatDOSTextLineBreaks = 5,

wdFormatRTF = 6,

wdFormatUnicodeText = 7,

wdFormatEncodedText = 7,

wdFormatHTML = 8

};

PPT:

enum PpSaveAsFileType

{

ppSaveAsPresentation = 1,

ppSaveAsPowerPoint7 = 2,

ppSaveAsPowerPoint4 = 3,

ppSaveAsPowerPoint3 = 4,

ppSaveAsTemplate = 5,

ppSaveAsRTF = 6,

ppSaveAsShow = 7,

ppSaveAsAddIn = 8,

ppSaveAsPowerPoint4FarEast = 10,

ppSaveAsDefault = 11,

ppSaveAsHTML = 12,

ppSaveAsHTMLv3 = 13,

ppSaveAsHTMLDual = 14,

ppSaveAsMetaFile = 15,

ppSaveAsGIF = 16,

ppSaveAsJPG = 17,

ppSaveAsPNG = 18,

ppSaveAsBMP = 19

};

*/

/*

0x32. 删除本地文件

HRESULT DeleteLocalFile([in] BSTR strFilePath);

参数:

strFileName:文件本地路径,如c:\\11.doc

*/

/*

0x33.创建临时文件

HRESULT GetTempFilePath([out,retval] BSTR* strValue);

返回:

临时文件的路径地址。使用完后,用DeleteLocalFile 删除

*/

/*

0x34.设置文档显示模式

HRESULT ShowView([in] long dwViewType, [out,retval] long * pbool);

dwViewType的可取值为:

enum WdViewType

{

wdNormalView = 1,

wdOutlineView = 2,

wdPrintView = 3,

wdPrintPreview = 4,

wdMasterView = 5, //这个是大纲

wdWebView = 6

};

*/

//大纲模式

document.all.FramerControl1.ShowView(5);

/*

0x39:下载远程文件

HRESULT DownloadFile( [in] BSTR strRemoteFile, [in] BSTR strLocalFile, [out,retval] BSTR* strValue);

参数:

strRemoteFile:远程路径地址,http or Ftp

strLocalFile: 本地保存地址,if strLocalFile == NULL then Create Temp File and return TempFile's Path

*/

/*

0x40:增加Http上传时候的,附加其他文件

HRESULT HttpAddPostFile([in] BSTR strFileID, [in] BSTR strFileName, [out,retval] long* pbool);

参数:

strFileID:文件的ID,供服务器端页面解析

strFileName: 本地文件地址

*/

/*

0x41,0x42.获取详细的修订信息。

GetRevCount( [out,retval] long * pbool);

GetRevInfo([in] long lIndex, [in] long lType, [out,retval] BSTR* pbool);

例子如下

*/

var vCount;

vCount = document.all.FramerControl1.GetRevCount();

alert(vCount);

var vOpt = 0;

var vDate;

for(var i=1; i<= vCount; i++){

vOpt = document.all.FramerControl1.GetRevInfo(i,2);

if("1" == vOpt){

vOpt = "插入";

}else if("2" == vOpt){

vOpt = "删除";

}else{

vOpt = "未知操作";

}

vDate = new String(document.all.FramerControl1.GetRevInfo(i,1));

vDate = parseFloat(vDate);

alert(vDate);

dateObj = new Date(vDate);

alert(dateObj.getYear() + "年" + dateObj.getMonth() + 1 + "月" + dateObj.getDate() +"日" + dateObj.getHours() +"时" + dateObj.getMinutes() +"分" + dateObj.getSeconds() +"秒" );

alert("用户:"+document.all.FramerControl1.GetRevInfo(i,0) + "\r\n操作:" + vOpt + "\r\n内容:" + document.all.FramerControl1.GetRevInfo(i,3));

}

/*

0x43.设置基本信息:

HRESULT SetValue([in] BSTR strValue, [in] BSTR strName, [out,retval] long* pbool);

1.设置文件只读密码

SetValue("password","::DOCPROP:PassWord");

2.设置文件修改密码

SetValue("password","::DOCPROP:WritePW");

返回值:

0 正确

-1:不支持此命令,请确定您的第二个参数没有传错

-127:异常

*/

//设置文件只读密码

document.all.FramerControl1.SetValue("password","::DOCPROP:PassWord");

//设置文件修改密码

document.all.FramerControl1.SetValue("password","::DOCPROP:WritePW");

/*

0x44.设置文档变量,这个很少能用到

HRESULT SetDocVariable([in] BSTR strVarName, [in] BSTR strValue,[in] long lOpt, [out,retval] long* pbool);

strVarName: 变量名

strVlaue:变量值

lOpt: 操作类型,

按位

第一位为1: 表示update域关联的

第二位为1: 表示如果没有这个变量则添加

第三位为1: 未来支持

return:

0:OK

-127:异常

*/

/*

0x45: 分页保存

HRESULT SetPageAs([in] BSTR strLocalFile, [in] long lPageNum, [in] long lType,[out,retval] long* pbool);

strLocalFile:本地路径

lPageNum:页数

*/

2Q==

已赞过

已踩过<

你对这个回答的评价是?

评论

收起

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: dsoframer_kb311765_x86.exe是一个可执行文件,是用于安装“Microsoft Office组件:Office Tools”中的一个特定补丁KB311765(针对32位系统)的程序。 这个补丁是由微软发布的,目的是修复Office Tools中的一个已知问题。据了解,此问题可能导致使用Office组件开发的应用程序在某些情况下出现崩溃或功能受限。 dsoframer_kb311765_x86.exe有两种可能的用途。一种是在安装了Office Tools但未安装此补丁的情况下使用,它会提供一个安装程序,以便用户可以轻松地将补丁应用到系统中。用户只需双击运行该文件,按照提示进行安装步骤,即可完成这个补丁的安装。 另一种用途是,如果用户已经安装了Office Tools并且同时安装了此补丁,那么dsoframer_kb311765_x86.exe可能会被用作卸载程序。用户只需双击运行该文件,按照提示进行卸载步骤,即可将KB311765补丁从系统中卸载。 无论用户是安装还是卸载此补丁,都应确保他们具备管理员权限,以确保操作的成功执行。 总之,dsoframer_kb311765_x86.exe是一个用于安装或卸载Office Tools中特定补丁KB311765的可执行文件。用户可以根据需要双击运行它,按照提示进行安装或卸载的步骤。 ### 回答2: dsoframer_kb311765_x86.exe 是微软为了修复 Office 2003 中文版的安全性漏洞而发布的一个更新补丁。这个更新补丁主要针对的是其中包含的一个组件——dsoframer.ocx文件。 dsoframer.ocx是用于在 Office 2003 中嵌入和编辑Office文档的一个ActiveX控件。然而,在一些特定的情况下,该控件存在安全漏洞,可能允许攻击者执行恶意代码。 为了解决这个安全漏洞问题,微软发布了dsoframer_kb311765_x86.exe这个更新补丁。通过安装这个补丁,用户可以修复dsoframer.ocx组件中的安全漏洞,提高Office 2003在处理嵌入文档时的安全性。 要安装这个更新补丁,你可以下载dsoframer_kb311765_x86.exe文件,并且以管理员身份运行该文件。安装程序将会自动检测你的系统环境,并进行相应的安装和修复操作。安装完成后,你的Office 2003中的dsoframer.ocx组件将会得到更新,并且安全漏洞会被修复。 总之,dsoframer_kb311765_x86.exe 是微软发布的一个更新补丁,用于修复Office 2003中文版中一个安全漏洞。用户可以通过安装这个补丁提高Office 2003在处理嵌入文档时的安全性。 ### 回答3: dsoframer_kb311765_x86.exe是一个可执行文件,它与Microsoft Office文档对象(DSO)有关。DSO是一种可用于通过编程方式访问Office文档的组件,它可以嵌入到应用程序中,使其能够打开、编辑和保存各种Office文档,如Word、Excel和PowerPoint等。 dsoframer_kb311765_x86.exe文件可能是一个更新程序,用于修复或改进DSO组件的功能。更新程序通常用于解决软件中的错误、漏洞或安全问题,并提供更好的用户体验和性能。 为了使用dsoframer_kb311765_x86.exe文件,您需要下载并运行该文件。运行安装程序后,它可能会检测您计算机上是否已经安装了较旧版本的DSO组件并将其升级为最新版本。或者,如果您尚未安装DSO组件,该程序可以帮助您安装它。 一旦完成安装,您的应用程序将能够使用DSO组件来处理、编辑和保存Office文档。这将增强应用程序的功能,使其能够与Office文档进行更加紧密的集成,并提供更多的操作选项和功能。 总之,dsoframer_kb311765_x86.exe是一个与Microsoft Office文档对象(DSO)相关的可执行文件,它可能是一个更新程序,用于安装最新版本的DSO组件,以增强应用程序与Office文档的集成和功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值