Jacob调用COM组件总结,实例

转自:http://blog.csdn.net/whw6_faye/article/details/5418506

最近做了一个Java Jacob调用COM组件的东西,其中遇到了不少问题,现在把经验总结一下和大家分享。

1.Jacob安装

Google一下,下载Jacob最新版。我这里用的是Jacob-1.15

把Jacob.jar放到你Java工程的lib目录下,引入项目

Jacob自带了两个dll, jacob-1.15-M3-x64.dll 和jacob-1.15-M3-x86.dll,把这两个放到C:/Windows/System32下,很多人忘了这一步导致后面调用失败

2.Jacob使用

引用Jacob包

[java] view plaincopy

  1. import com.jacob.activeX.*;
  2. import com.jacob.com.*;

(1) COM组件名称

调用COM组件的时候,很多人都在网上抄来抄去(主要是调用Word),而没有弄明白其中的原理.

首先,COM组件有一个全局的名称,制作COM组件的时候必须指定,这个名称可以用Windows 2000或Windows 2003的Oleview工具查看到,在Visual Studio中Add reference中看到的是COM组件的描述,不是名称!

例如

ActiveXComponent comObj = new ActiveXComponent("Word.Application");

COM组件的名字叫 "Word",而Application是COM组件中实现的一个对象.

如果自己做一个COM组件叫 A, 里面有一个 ICalc的接口, Calc实现了ICalc接口

那么应该这么调用: ActiveXComponent comObj = new ActiveXComponent("A.Calc");

(2)IDispatch

COM组件中的接口必须派生自 IDispatch, 否则Jacob无法调用!

我在做一个测试COM组件的时候碰到了这个问题, 我的接口派生自 IUnknown, 所以jacob提示无法找到dispatch interface

当然,几乎所有的商业COM组件都是实现了IDispatch接口的

(3)数据类型, 参数

VB, VC++, Delphi, VS 这样的开发工具都可以创建COM组件,但是数据类型上需要注意.

Delphi做的COM组件处理字符串一定要使用 WideString类型, 在TypeLib 里需要用 BSTR 或者 BSTR*,

用LPSTR 或者 LPSTR * (在Delphi里映射为PChar (PAnsiChar)) 做的参数, .NET里可以调,但是Java里用jacob就不行了

另外参数的 in, out 很关键, 尽量不要用 in,out 这样的参数, 而是 in a, out b 这样

对于字符串, 如果是out , 那么COM组件中要为这个字符串构造内存空间再设值,    Delphi中 字符串是值类型, 这个一定要注意

GetMem(a, 1000);

FillChar(a^, 1000, 0);

StrCopy(......)

jacob中调用的时候,如果要返回字符串,一定要这样写

[java] view plaincopy

  1. String str = "";
  2. Variant v = new Variant(str, true);
  3. comObj.call("HelloWorld", v);

new Variant()的第二个参数,指定是否强制按引用传递 (byref), 对于COM组件中是 out 类型的参数适合用这种

3. 实际应用

以上是我总结的一些经验,实际应用没有那么复杂.大部分人就是用jacob来操作Office系列组件而已

而Word, Excel这样的COM组件包含了很多属性, 所以是 comObj.getProperty (......) 不需要 2 部分那么多注意点

具体例子就不贴了,操作Word.Excel去google一下,例子很多

如果你需要调用其他的一些COM组件,那么就要注意第二段的一些注意点

时间: 2024-10-28 23:30:46

Jacob调用COM组件总结,实例的相关文章

java调用com组件操作word使用总结(jacob)

ava调用com组件操作word使用总结(jacob) 简单描述 在此处输入简单摘要 特别声明:使用java-com技术可以完成任何VBA可以完成的office文档操作; 一.准备工作 先了解一下概念,JACOB 就是 JAVA-COM Bridge的缩写,提供自动化的访问com的功能,也是通过JNI功能访问windows平台下的com组件或者win32系统库的.这是一个开始于 1999年的开源项目的成果,有很多使用者对该项目进行了修改,做出了自己的贡献. Jacob下载地址: http://s

NET调用Com组件事例

http://blog.csdn.net/shizhiyingnj/article/details/1507948 在程序设计中,往往通过键盘的某个按键来完成相关操作! 下面就来说明如何实现: 1.引入名称空间; using System.Runtime.InteropServices; (由于使用到API(user32.dll) 2.使用API [DllImport("user32.dll", CharSet = CharSet.Auto)]  private static exte

VS2010调用Com组件

Com组件开发过程中用的不多,资料也不多,故记录开发Com组件中的部分问题. 在这一篇文章里,讲解了如何使用VS2010创建Com组件.现在基于该文章创建的Com组件接口,创建VC++项目来调用该接口. 使用流程 新建win32控制台项目. 主文件代码如下: #include "stdafx.h" #include "../testCom/testCom_i.h" #include "../testCom/testCom_i.c" int _tm

C语言调用COM组件

调用COM组件最简单的语言当然是C++,但在某些情况下,不得不用C语言.本文介绍用C语言调用COM组件的方法. 为了更好的理解C的做法,我们要先看一看C++调用COM组件是怎么做的. 一.C++方式 从 Windows 7 开始,任务栏可以显示进度条,就以这个接口为例吧. ITaskbarList4 *pTaskbar = nullptr; HRESULT hResult = ::CoCreateInstance(CLSID_TaskbarList, nullptr, CLSCTX_INPROC

vue组件之间的通信以及如何在父组件中调用子组件的方法和属性

在Vue中组件实例之间的作用域是孤立的,以为不能直接在子组件上引用父组件的数据,同时父组件也不能直接使用子组件的数据 一.父组件利用props往子组件传输数据 父组件: <div> <child v-bind:my-message="parentMsg"></child>//注意传递参数时要用-代替驼峰命名,HTML不区分大小写 </div> 子组件: Vue.component('child', { // camelCase in Ja

[转]C# 互操作性入门系列(四):在C# 中调用COM组件

传送门 C#互操作系列文章: C#互操作性入门系列(一):C#中互操作性介绍 C#互操作性入门系列(二):使用平台调用调用Win32 函数 C# 互操作性入门系列(三):平台调用中的数据封送处理 C#互操作性入门系列(四):在C# 中调用COM组件 本专题概要: 引言 如何在C#中调用COM组件--访问Office 互操作对象 在C# 中调用COM组件的实现原理剖析 错误处理 小结 一.引言 COM(Component Object Modele,组件对象模型)是微软以前推崇的一个开发技术,所以

vue.js组件之间通讯--父组件调用子组件的一些方法,子组件暴露一些方法,让父组件调用

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Title</title></head><body><div id="app"></div></body><script src="node_modules/vue/

React 深入系列1:React 中的元素、组件、实例和节点

文:徐超,<React进阶之路>作者 授权发布,转载请注明作者及出处 React 深入系列,深入讲解了React中的重点概念.特性和模式等,旨在帮助大家加深对React的理解,以及在项目中更加灵活地使用React. React 中的元素.组件.实例和节点,是React中关系密切的4个概念,也是很容易让React 初学者迷惑的4个概念.现在,老干部就来详细地介绍这4个概念,以及它们之间的联系和区别,满足喜欢咬文嚼字.刨根问底的同学(老干部就是其中一员)的好奇心. 元素 (Element) Rea

小白初学Vue之 组件与实例的关系 初试篇

内容:组件和实例 一.组件和实例的关系 先看下之前的代码,来看下整体的架构 1 <!DOCTYPE html> 2 <html> 3 4 <head> 5 <meta charset="UTF-8"> 6 <title>拆分组件</title> 7 <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/vue.js"