呼叫中心业务,交换机 ,CTI中间件,ocx控件,java应用,以上构成整个呼叫中心的基础业务流程
这其中作为程序开发需要涉及的就数java调用ocx控件了。
通过java调用ocx控件的方式:
1.JNI 最直接的方式,也是最麻烦的方式,需要自己完成所有的工作,不推荐。
2.Jawin 尝试了一下,效果不错,但相对来说,其编程风格更贴近Windows,离Java有点远 。
3.Jacob 使用Jacob非常方便,Java编程风格,需要了解的知识比较少。
下面介绍jacob的使用:
官方网站:http://danadler.com/jacob/
下载路径:http://danadler.com/jacob/jacobSrc_17.zip
稳定版本:http://sourceforge.net/projects/jacob-project/
1.解压下载之后的文件
2.把 jacob.dll 拷贝到 jdk\bin或者C:\WINDOWS\system32目录下。
3.导入 jacob.jar 这个包到你的工程JAR包
4.注册ocx控件
把***.ocx控件放入c:\windows\system32 文件夹下
在cmd命令行下,输入regsvr32 ***.ocx命令进行注册
需要注意的地方: jacob.jar, jacob.dll 请保持版本一致。
相应的Java代码:
ActiveXComponent com = new ActiveXComponent("组件的ProgID") ; Dispatch disp = com.getObject();
其中的组件的progId的得到方式:
progId:即CLSID,控件id.
如想得到它呢。需要到注册表去查找。在HKEY_CLASSES_ROOT下查找你的控件名,当找到时,在其文件夹下找到progID项,即可看到它的CLSID.
如果CLSID不对,
会报如下异常: com.jacob.com.ComFailException: Can't get object clsid from progid
其他异常:
java.lang.UnsatisfiedLinkError: no jacob in java.library.path
原因是:没有把 jacob.dll 拷贝到 jdk\bin或者C:\WINDOWS\system32目录下
2.调用控件里面的方面
2.1 调用无参的方法,并返回一个short值
Dispatch.call(disp, "Init").getShort();
2.2 调用有一个参数的方法,并返回一个boolean值
Dispatch.call(disp,"Method",new Variant(args)).getBoolean();
调用多个参数依次类推,注意在传递参数前,将Java中的参数转换成Variant。
在调用方式时,有可能会抛出以下异常:
Exception in thread "main" com.jacob.com.ComFailException: A COM exception has been encountered: At Invoke of: LoadFile Description: 灾难性故障 at com.jacob.com.Dispatch.invokev(Native Method) at com.jacob.com.Dispatch.invokev(Dispatch.java:858) at com.jacob.com.Dispatch.callN(Dispatch.java:455) at com.jacob.com.Dispatch.call(Dispatch.java:544) at com.lv.office.AIPToTest.jacob(AIPToTest.java:24) at com.lv.office.AIPToTest.main(AIPToTest.java:14)
解决方法:
在OCX控件中,重写COleControl.IsInvokeAllowed (DISPID)方法,即在控件的CMyNameCtrl中增加一个方法
BOOL CMyNameCtrl::IsInvokeAllowed (DISPID)
{
return TRUE;
}
用这个方法的理由是:
这个错误是由ActiveX结构设计造成的。
在Ole4.0版本之前,外部程序是可以直接调用OCX中方法的。Ole4.0之后,每次调用控件中的方法,系统会自动检查是否允许调用,即运行COleControl.IsInvokeAllowed (DISPID)
该方法检查控件是否正确的初始化或者是否通过持久存储接口正确加载,如果两个条件有一个满足,即返回TRUE,否则返回FALSE。
当控件在MFC中使用时,很多细节,如初始化,都被过滤了,这样,大多数用户都不会遇到这个问题。但是,当我们从C、C++的dll中调用控件时,不满足上述条件,该方法返回FALSE,这时候再调用任何控件方法,都会出现上述异常。