现在的位置: 首页 > 综合 > 正文

[Domino]Java访问Domino必需配置的服务器设置

2013年06月14日 ⁄ 综合 ⁄ 共 2614字 ⁄ 字号 评论关闭

 

[Domino]Java访问Domino必需配置的服务器设置

编写者

日期

关键词

郑昀@ultrapower

2005-6-30

Java Domino Configuration

应用场景

我们需要通过Java远程访问IBM Lotus Domino R6R5服务器,从中获取用户邮箱的邮件信息等关键数据。我们不需要提供每一个用户密码以及ID文件。

我们的具体做法是,通过Domino ORB,来使得Domino ServerJava远程交互,双方使用IIOP来交互和交换对象数据。

访问的Domino服务器必须配置本文讲述的四个设置,否则会在Domino R6上得到以下错误:

错误日志片段:

错误代码为4488

lotus.domino.NotesException

 at lotus.domino.NotesExceptionHelper.read(NotesExceptionHelper.java)

 at lotus.domino.NotesExceptionHolder._read(NotesExceptionHolder.java)

at com.ibm.CORBA.iiop.RepImpl.invoke(RepImpl.java:325)

 at com.ibm.CORBA.portable.ObjectImpl._invoke(ObjectImpl.java:36)

 at lotus.domino.corba._IObjectServerStub.createSession(_IObjectServerStub.java)

 at lotus.domino.cso.Session.OREFtoSession(Session.java:829)

 at lotus.domino.cso.Session.<init>(Session.java:72)

 at lotus.domino.cso.Session.createSession(Session.java:40)

 

Domino R5上则得到如下错误:

错误日志片段:

错误代码为4536

lotus.domino.NotesException

    at lotus.domino.NotesExceptionHelper.read(NotesExceptionHelper.java:48)

    at lotus.domino.NotesExceptionHolder._read(NotesExceptionHolder.java:25)

    at com.ibm.CORBA.iiop.RepImpl.invoke(RepImpl.java:325)

    at com.ibm.CORBA.portable.ObjectImpl._invoke(ObjectImpl.java:36)

    at lotus.domino.corba._IObjectServerStub.createSession(_IObjectServerStub.java:154)

这两个错误都代表“服务器拒绝访问”。

 

下面列出需要配置的四个安全设置。

DIIOP设置

请实施工程师检查Domino ServerDIIOP设置是否和图1一致。

设置范围:此设置对Domino R5/6都有效。

设置生效:Domino R5版本中,修改并保存IIOP设置后,必须重新启动Domino Server,否则无法生效。

检查 Domino Directory Server 文档。转至 Ports 选项卡,然后转向 Internet Ports 选项卡。查看 DIIOP 选项卡,Authentication options中的Name & password应该是Yes,如下图所示。这些部分有用于指定端口号以及启用/禁用端口的字段。下图显示了 Internet Ports--DIIOP 选项卡:


1 IIOP设置

特别要注意的是,在Domino R5版本中,修改并保存IIOP设置后,应该重新启动Domino Server,否则无法生效。即使命令tell diiop refresh强制刷新,也不能使修改生效。

而在Domino R6版本中,改进了这一功能,不需要重启服务器也不需要强制刷新,即可使这项IIOP设置修改生效!

各项参数的具体含义是:

No.

Items

Descriptions

1

Name and Password

DIIOP 验证需要名称和密码

2

Anonymous

DIIOP 验证不需要名称和密码

3

Enforce server access settings

DIIOP 使用 Security 选项卡下的 Server Access 设置

Access Server设置

请实施工程师检查Domino ServerAccess Server设置是否和图2一致。

设置范围:此设置对Domino R5/6都有效。

检查 Domino Directory Server 文档。转至 Security 选项卡,然后查看 Server Access中的Access Server应该是All users can access this server,如下图所示。

2 Access Server设置

Programmability  Restrictions设置

请实施工程师检查Domino ServerProgrammability  Restrictions设置是否和图3或者图4一致。

设置范围:此设置对Domino R5R6是有区别的。

设置生效:Domino R5版本中,修改并保存此设置后,必须命令tell diiop refresh强制刷新,否则无法生效。

检查 Domino Directory Server 文档。转至 Security 选项卡,然后查看Programmability  Restrictions” 

对于Domino R6,总共需要2处权限设置为“*

    请找到以下2个设置:

l         Run unrestricted methods and operations:

l         Sign agents to run on behalf of someone else:

   请您为这些设置输入“*”,表示允许所有用户。

       作了修改之后,保存并退出。

然后还需要在服务器命令行界面上输入命令“tell diiop refresh”,强制diiop刷新策略。

那么最终的效果应该如下图所示:

3 R6 Programmability  Restrictions

抱歉!评论已关闭.