Java 对 Domino Objects 的访问是通过高级包 lotusdomino 进行的根据运行时环境这个包中的接口是在其他两个包中的一个包中实现的
lotusdominolocal 提供了从同一计算机上的 Notes/Domino 软件进行调用
lotusdominocso 提供了从通过远程连接访问的 Domino 服务器进行调用
对于本地访问Java 程序运行在安装有 Notes 客户机或者 Domino 服务器的计算机上本地类由 JNI(Java Native Interface)构建来用于访问与 JVM(Java Virtual Machine)相同的进程中的 Notes/Domino 二进制文件对于远程访问Java 程序使用 CORBA(Common Object Request Broker Architecture)请求 Domino 服务器所提供的服务远程类使用 CORBA 通过 TCP/IP 网络访问服务器远程访问由以下两个部分组成
客户机通过 HTTP 协议获得服务器的初始对象作为 IOR (Interoperable Object Reference)
客户机通过 IIOP 连接进一步获得其他对象
在 lotusdomino 中NotesFactory 类提供了 createSession 和其他方法以便在 Java 应用程序和 servlet 中启用对 Domino Objects 的访问特殊的调用方式确定了访问是本地还是远程的要编译使用 lotusdomino 包的 Java 程序类路径必须包含 Notesjar(本地)或者 NCSOjar(远程)例如
set classpath=%classpath%;c:\lotus\domino\Notesjar 或者 set classpath=%classpath%;c:\lotus\domino\data\domino\java\NCSOjar 其中 Notesjar 可以在任何 Notes/Domino 安装的程序目录中找到NCSOjar 可以在 Domino Designer 或 Domino 服务器数据目录下的 domino\java 目录中找到
本地调用
createSession 的调用没有参数第一个参数为 null 或者第一个参数为空字符串都表示本地调用下列代码是等价的
Session s = NotesFactorycreateSession()
Session s = NotesFactorycreateSession((String)null)
Session s = NotesFactorycreateSession()
将 null 转换成 String以避免过载沖突要从应用程序和 servlet 中实现本地调用路径中必须包含 Notes/Domino 的程序目录类路径中必须包含 Notes/Domino 程序目录中的 Notesjar例如
set path := %path%;c:\lotus\domino
set classpath := %classpath%;c:\lotus\domino\Notesjar
Notesjar 中包含 lotusdomino 和 lotusdominoloca 包本地调用需要用 NotesThread 类管理线程NotesThread 类扩展了 javalangThread包含专门针对 Domino 的初始化和终止代码您有以下三种选择
通过继承来执行线程
通过 Runnable 接口来执行线程
通过静态方法来执行线程
通过继承来执行线程
要通过继承来执行线程需要扩展 NotesThread而不是 Thread并且需要包含 runNotes 方法而不是 run 方法NotesThread 线程可以和任何其他线程一样通过 start 方法来启动这种方式比静态方法(稍后讨论)容易使用且不易出错
import lotusdomino*;
public class myClass extends NotesThread
{
public static void main(String argv[])
{
myClass t = new myClass();
tstart();
}
public void runNotes() // entry point for Notes thread
{
try
{
Session s = NotesFactorycreateSession();
// Operational code goes here
}
catch (Exception e)
{
eprintStackTrace();
}
}
}
通过 Runnable 接口来执行线程
要通过 Runnable 接口来执行线程需要实现 Runnable 并包含 run 方法这与使用线程的任何类相同当您因为正在扩展其他类而不能扩展 NotesThread 时可以使用这种方式
import lotusdomino*;
public class myClass implements Runnable
{
public static void main(String argv[])
{
myClass t = new myClass();
NotesThread nt = new NotesThread((Runnable)t);
ntstart();
}
public void run() // entry point for thread
{
try
{
Session s = NotesFactorycreateSession();
// Operational code goes here
}
catch (Exception e)
{
eprintStackTrace();
}
}
}
通过静态方法来执行线程
要通过静态方法来执行线程需要调用 sinitThread() 来初始化线程调用 stermThread() 来终止线程stermThread() 的调用必须与 sinitThread() 的调用严格一一对应推荐将 stermThread 放在finally程序块里静态方法适用于不可能进行继承的线程或者适用于需要更好地控制基于事件的线程
import lotusdomino*;
public class myClass
{
public static void main(String argv[])
{
try
{
NotesThreadsinitThread(); // start thread
Session s = NotesFactorycreateSession();
// Operational code goes here
}
catch(Exception e)
{
eprintStackTrace();
}
finally
{
NotesThreadstermThread(); // must terminate every thread
}
}
}
进行本地调用的每个应用程序的线程都必须初始化一个 NotesThread 对象它包含了访问 Domino Objects 的 AWT 线程监听器线程必须使用静态方法因为无法从 NotesThread 中继承它们 既进行本地调用又进行远程调用的应用程序可以动态地决定何时使用静态方法 sinitThread 和 stermThread运行本地线程时也可以进行远程调用但不要将通过一个会话获得的对象用于对其他会话的调用应该避免使用多线程除非有非常充分的理由比如处理文件输入/输出和 Web 请求时要继续进行操作观察遵循以下指导原则
在同一会话中可以跨线程共享同步和回收 Domino
Objects如果每个线程使用不同的会话那么就会失去这些功能必须明确地在每个线程的基础上管理同步和回收
不要跨线程使用 DbDirectory
允许在多线程中访问现有文档但只在一个线程中进行访问文档将简化内存管理将访问限制在一个线程这样就可以不检查其他线程直接进行回收跨线程创建文档始终是安全的并且这些对象可以不管其他线程就进行回收
配置文件文档是基于每个线程进行缓存的如果出现更新竞争那么将保留最后一个线程的更新
注意不要删除其他线程中通过视图或集合进行导航所需的文档
当子对象被用于其父对象之外的其他线程时父线程要等所有子线程都结束后才能结束当在 AWT 事件处理程序中使用 Domino Objects 时这一点尤其重要
远程调用
在进行远程调用时createSession 签名的第一个参数是非空字符串第一个参数通常用来标识 Domino 服务器所在的计算机例如
Session s = NotesFactorycreateSession()
或者
Session s = NotesFactorycreateSession(:)
第二个示例指定了端口号这样就无需在 上运行 Domino Web 服务器
要从应用程序或者 servlet 执行远程调用客户机计算机的类路径中必须包含 NCSOjarNCSOjar 包含 lotusdomino 包lotusdominocso 包rba 包以及 ORB 类ORB 类包含用于远程类的实现代码对于已安装的 Domino Designer 和 Domino 服务器软件NCSOjar 位于 Domino 数据目录下的 domino\java 子目录中对于没有安装 Domino 软件的计算机必须从安装该软件的计算机上复制归档文件
类路径必须包含归档文件例如
set classpath := %classpath%;c:\lotus\domino\data\domino\java\NCSOjar
编码
编码比较简单远程调用不使用 NotesThread只需使用主机名称和(可选)端口号进行 createSession 调用即可
不使用线程时模板将如下所示
import lotusdomino*;
public class myClass
{
public static void main(String argv[])
{
try
{
String host = :;
Session s = NotesFactorycreateSession(host);
// Operational code goes here
}
catch(Exception e)
{
eprintStackTrace();