第1章 分布式应用模式概览 1
1.1 客户机-服务器应用模式 1
1.1.1 客户机-服务器(C/S)体系结构 1
1.1.2 浏览器-服务器(B/S)体系结构 3
1.1.3 C/S和B/S体系结构的优势与不足 3
1.2 分布式多层应用体系结构 4
1.2.1 分布式多层体系结构 5
1.2.2 分布式多层体系结构各逻辑层的特征 7
1.3 中间件的基本概念 7
1.3.3 基于中间件的软件系统开发和部署方式 8
1.3.2 中间件的基本特征 8
1.3.1 中间件的定义 8
1.4 小结 9
第2章 CORBA体系结构的基本内容 10
2.1 CORBA体系结构概述 10
2.1.1 CORBA的概念 10
2.1.2 CORBA规范的特点 11
2.1.3 对象请求代理的概念和作用 11
2.1.4 CORBA中的对象模型 12
2.2 客户端CORBA对象 13
2.3 服务对象端CORBA对象 14
2.4 客户端存根 15
2.5 服务对象框架 18
2.6 对象请求代理 22
2.6.1 ORB传递服务请求的过程 23
2.6.2 ORB初始化方法 24
2.6.3 解析初始引用方法 25
2.6.4 对象字符串化和字符串对象化方法 26
2.6.5 ORB启动 28
2.7 动态调用接口(Dynamic Invoke Interface,DII) 28
2.7.1 客户端提出服务请求的方式 28
2.7.2 静态调用请求和动态调用请求的区别 28
2.8 动态框架接口 29
2.9 接口仓库 30
2.10 对象适配器(Object Adapter) 31
2.11 实现仓库 32
2.12 ORB互操作 33
2.12.1 通用ORB间互操作协议 34
2.12.2 环境相关的ORB互操作协议 34
2.13 CORBA基本服务 35
2.14 CORBA工具 38
2.15 小结 39
第3章 OMG IDL语法结构 40
3.1 OMG IDL接口定义文件举例 40
3.2.1 注释风格 41
3.2.2 标识符 41
3.2 词法规则 41
3.2.3 字面量 42
3.3 基本数据类型 42
3.4 复合数据类型 43
3.4.1 结构类型 43
3.4.2 联合类型 45
3.4.3 枚举类型 45
3.4.4 序列类型 46
3.4.5 字符串类型 47
3.4.6 数组类型 47
3.5 模块 47
3.6 接口 48
3.7 属性和只读属性 49
3.8 方向性说明 49
3.9 方法 49
3.10 单向调用请求 50
3.11 接口继承 51
3.11.1 单继承接口定义方式 51
3.11.2 多继承接口定义方式 51
3.11.3 前置声明 52
3.11.4 接口的跨模块继承 52
3.12 异常 53
3.12.1 CORBA异常定义 53
3.12.2 CORBA系统异常 54
3.12.3 CORBA用户异常 56
3.13 上下文 57
3.14 小结 58
第4章 OMG IDL与Java语言的映射关系 59
4.1 Helper类 59
4.1.1 IDL接口定义映射生成Helper类规范 59
4.1.2 IDL复合数据类型映射Helper类 63
4.1.3 IDL衍生数据类型映射Helper类 65
4.2 Holder类 67
4.2.1 IDL基本数据类型映射Holder类代码 67
4.2.2 IDL定义的接口对象映射Holder类代码 68
4.2.3 IDL用户定义数据类型映射Holder类代码 69
4.3 IDL常量的映射 71
4.3.1 在IDL接口定义内部定义的常量 71
4.3.2 在IDL接口定义外部定义的常量 72
4.4 IDL基本数据类型的映射 72
4.5 复合数据类型的映射 74
4.5.1 枚举类型的映射 74
4.5.2 结构类型映射 77
4.5.3 联合类型的映射 80
4.5.4 序列类型的映射 83
4.6 模块的映射 83
4.7 接口的映射 83
4.7.2 接口继承的映射 84
4.7.1 特征接口和方法接口的定义 84
4.8 IDL异常的映射 86
4.9 标识符typedef定义数据类型的映射 88
4.10 属性定义的映射 90
4.11 CORBA对象的映射 90
4.11.1 环境对象的映射 91
4.11.2 名—值对象的映射 91
4.11.3 名—值列表对象的映射 92
4.11.4 上下文对象的映射 93
4.11.5 上下文列表对象 94
4.11.6 请求对象 95
4 11.7 类型码 97
4.11.8 对象请求代理 98
4.11.9 Any数据类型 98
4.12 小结 100
第5章 idl2java映射文件分析 101
5.1 定义和映射IDL接口定义文件 101
5.2 接口对象的客户端存根文件 102
5.3 服务对象端POA框架文件 103
5.4 接口对象定义文件 104
5.5 接口对象映射的Helper类文件 104
5.6 接口对象映射的Holder类文件 106
5.8 接口对象的POA框架代理类 107
5.7 接口对象映射的方法类文件 107
5.9 小结 108
第6章 VisiBroker的基本内容 110
6.1 VisiBroker中的ORB服务工具 110
6.2 基于VisiBroker开发分布式应用系统过程 111
6.3 VisiBroker的下载和安装 112
6.3.1 VisiBroker的下载 112
6.3.2 VisiBroker的安装过程 112
6.4 VisiBroker for Java4.5.1安装目录的构成 117
6.5 idl2java 118
6.6 idl2ir 119
6.8 java2idl 120
6.7 idl2idl 120
6.9 java2iiop 121
6.10 vbjc 122
6.11 vbj 122
6.11.1 vbj运行客户端程序选项 122
6.11.2 vbj运行服务对象端程序选项 123
6.12 Smart Agent 123
6.13 osfind 124
6.14 irep 125
6.15 oad 125
6.16 oadutil 126
6.17 可视化对象管理工具 127
6.17.1 定位服务管理 128
6.17.3 实现仓库管理 129
6.17.2 命名服务管理 129
6.17.4 接口仓库管理 130
6.17.5 服务对象管理 131
6.18 小结 132
第7章 基于VisiBroker开发分布式应用 133
7.1 基于VisiBroker创建分布式应用程序过程 133
7.2 人力资源管理分布式应用功能 134
7.2.1 系统分析 134
7.2.2 服务实现对象UML类图 134
7.3 IDL定义服务对象功能 134
7.5.1 初始化对象请求代理 135
7.5.2 定位并绑定服务对象 135
7.4 将IDL接口定义映射到Java语言 135
7.5 编写客户端应用 135
7.5.3 调用服务实现对象方法 136
7.5.4 客户端应用程序完整代码 136
7.6 编写服务对象应用程序 137
7.6.1 获取服务对象端对象请求的代理初始化引用 137
7.6.2 获取对根POA的引用 137
7.6.3 创建服务POA 137
7.6.4 服务实现对象实例化 137
7.6.5 激活服务实现对象 137
7.6.8 服务对象应用程序完整代码 138
7.6.6 激活根POA 138
7.6.7 启动服务对象 138
7.6.9 服务实现程序代码 139
7.7 分布式应用的运行 140
7.8 分布式应用系统的部署 141
7.9 小结 141
第8章 可移植对象适配器 142
8.1 可移植对象适配器的含义 142
8.2 POA的服务策略 143
8.2.1 生命期策略 143
8.2.6 请求处理策略 144
8.2.8 绑定支持策略 144
8.2.7 明确激活策略 144
8.2.4 服务实现对象的标识赋值策略 144
8.2.5 服务实现对象维护策略 144
8.2.3 线程策略 144
8.2.2 对象标识惟一性策略 144
8.3 获取对根POA的引用和创建服务POA 145
8.3.1 获取根POA的引用 145
8.3.2 创建服务POA 145
8.4 管理POA的状态 146
8.5 激活服务对象 147
8.6 服务对象与服务管理对象 148
8.7.1 线程池(Thread Pooling)模型 149
8.7 VisiBroker的线程策略模型 149
8.7.2 会话线程(Thread—persession)模型 151
8.8 小结 152
第9章 基于动态调用接口和动态框架接口创建分布式应用 153
9.1 创建基于动态调用接口的客户端程序 153
9.1.1 创建动态调用的客户端存根 153
9.1.2 获取对服务实现对象引用 153
9.1.3 创建请求对象 154
9.1.4 配置方法调用参数 155
9.1.5 设置返回值类型 156
9.1.6 发出调用请求,等待返回结果 156
9.1.7 查询服务对象返回结果 157
9.1.8 返回结果的解析 158
9.2 基于动态调用方式客户端应用程序完整代码 158
9.3 创建基于动态框架接口的服务实现对象程序 159
9.4 基于动态调用方式的服务实现对象程序代码 162
9.5 创建服务对象程序 164
9.6 基于动态调用方式分布式应用程序的运行 165
9.7 小结 166
第10章 定位服务的应用 167
10.1 定位服务的概念 167
10.2 获取定位服务代理实例 167
10.3 对象实例信息查询方法 168
10.4 对象接口定义信息查询完整代码 170
10.5 监听器类方法 171
10.6 编写监听器句柄 172
10.6.1 对象就绪状态消息发送方法 172
10.6.2 对象关闭状态消息发送方法 173
10.7 在对象定位代理中以监听器方式注册实现对象 174
10.8 小结 175
第11章 命名服务的应用 177
11.1 命名服务的概念 177
11.2 命名上下文 178
11.3 获取命名服务对象 181
11.5 基于命名服务客户端应用程序设计 183
11.4 命名服务支持工具 183
11.6 基于命名服务的服务对象程序设计 184
11.7 运行基于命名服务应用程序的选项 187
11.8 基于命名服务分布式应用程序的编译和运行 188
11.9 小结 189
第12章 事件服务的应用 190
12.1 事件服务概述 190
12.2 事件处理模型和事件对象接口 192
12.2.1 发送事件模型 192
12.2.2 接收事件模型 194
12.3 事件管理对象 196
12.4 事件通道 197
12.5 创建事件服务应用程序 199
12.6 小结 203
第13章 接口仓库的应用 204
13.1 接口仓库的概念 204
13.2 IDL接口名称与接口定义标识 204
13.3 接口仓库中对象定义 205
13.3.1 模块定义对象 205
13.3.2 接口定义对象 205
13.3.3 方法定义对象 207
13.3.4 属性定义对象 208
13.3.6 序列定义对象 209
13.3.5 常量定义对象 209
13.3.7 结构定义对象 210
13.3.8 字符串定义对象 210
13.3.9 枚举定义对象 211
13.3.10 异常定义对象 211
13.4 接口仓库的创建和维护 213
13.4.1 基于命令行方式的接口仓库管理 213
13.4.2 接口仓库对象定义 213
13.5 接口仓库应用程序设计 214
13.6 小结 215
14.2 启动对象激活进程服务 217
14.3 对象激活进程中注册对象的管理 217
第14章 对象激活进程的应用 217
14.1 服务对象的自动激活机制 217
14.3.1 注册实现对象 218
14.3.2 取消对象注册 218
14.3.3 查看对象激活进程的内容 218
14.4 基于对象激活进程应用程序设计方法 219
14.4.1 对象激活进程对象的IDL定义 219
14.4.2 实现对象信息描述结构 221
14.4.3 在对象激活进程中注册实现对象程序设计 222
14.5 小结 224
15.1 URL命名服务 225
15.2 URL命名服务对象 225
第15章 URL命名服务的应用 225
15.3 基于URL命名服务的客户端程序设计 226
15.4 基于URL命名服务的服务对象程序 227
15.5 小结 229
第16章 基于JBuilder5和VisiBroker开发分布式应用 230
16.1 JBuilder5简介 230
16.2 JBuilder5 Enterprise版的安装和许可证配置 231
16.2.1 JBuilder5企业版的安装 231
16.2.2 JBuilder5的许可证配置 232
16.3 JBuilder5和VisiBroker的整合 234
16.3.1 配置ORB库 234
16.3.2 选择ORB产品 236
16.3.5 设置新建项目的默认设置 237
16.3.4 设置VisiBroker库集合路径 237
16.3.3 设置VisiBroker工具路径 237
16.4 基于JBuilder5和VisiBroker创建分布式应用的过程 238
16.5 创建JBuilder5工程 239
16.6 定义IDL接口 240
16.7 映射客户端存根和服务对象框架代码 241
16.8 编写客户端程序 242
16.8.1 创建客户端应用程序 242
16.8.2 设计客户端应用程序用户界面 243
16.8.3 编写客户端调用服务对象方法代码 245
16.9.1 创建服务对象程序 246
16.9 编写服务对象和服务对象实现代码 246
16.9.2 编写服务实现对象中商务方法代码 248
16.10 分布式应用的运行和部署 250
16.11 小结 251
第17章 模拟人力资源管理分布式应用实例 253
17.1 人力资源管理分布式应用系统分析 253
17.1.1 系统功能描述 253
17.1.2 分布式应用服务对象的IDL接口定义 254
17.1.3 客户端应用UML类图描述 255
17.1.4 服务对象UML类图描述 256
17.1.5 分布式应用配置图 257
17.2.2 编写IDL接口定义文件 258
17.2.1 创建服务对象工程 258
17.2 服务对象应用程序设计 258
17.2.3 创建服务对象程序 259
17.2.4 编写人力资源经理对象HRManager实现代码 259
17.2.5 编写PersonalInfo对象实现代码 262
17.3 客户端应用程序设计 263
17.3.1 创建客户端应用工程 263
17.3.2 编写IDL接口定义文件 263
17.3.3 创建客户端应用 263
17.3.4 创建客户端图形用户界面设计 263
17.3.5 插入CORBA对象调用接口 264
17.3.6 编写创建注册员工信息请求方法 265
17.3.7 编写创建删除员工注册信息请求方法 267
17.3.8 编写查询员工注册信息方法 268
17.4 分布式应用系统的部署和运行 269
174.1 编译客户端和服务对象端应用程序 269
17.4.2 分布式应用系统的部署 269
17.4.3 启动服务对象应用 269
17.4.4 启动客户端应用 270
17.5 小结 270
第18章 模拟ATM机分布式应用实例 271
18.1 模拟ATM机的分布式应用系统分析 271
18.1.1 模拟ATM机分布式应用系统功能描述 271
18.1.2 ATM机分布式应用系统功能描述 271
18.1.3 分布式应用服务对象功能IDL描述 272
18.1.4 客户端应用UML类图描述 273
18.1.5 服务对象端应用UML类图描述 274
18.1.6 分布式应用UML配置描述 275
18.2 模拟ATM分布式应用系统服务对象端应用程序设计 276
18.2.1 创建服务对象工程 276
18.2.2 编写IDL接口定义文件 276
18.2.3 创建服务对象程序 277
18.2.4 编写ATMServer对象实现代码 277
18.2.5 编写ATMClient对象实现代码 279
18.3.3 创建客户端应用 281
18.3.4 图形用户界面设计 281
18.3.1 创建客户端工程 281
18.3.2 编写IDL接口定义文件 281
18.3 ATM分布式应用系统客户端程序设计 281
18.3.5 插入CORBA对象调用接口 282
18.3.6 编写创建信用卡账户方法代码 283
18.3.7 编写利用ATM系统客户端存款的方法代码 284
18.3.8 编写利用ATM客户端从指定账户取款方法代码 284
18.3.9 编写利用ATM客户端查询账户余额方法的代码 285
18.4 ATM分布式应用系统的部署和运行 286
18.4.1 编译客户端和服务对象应用程序 286
18.5 小结 287
18.4.4 启动客户端应用 287
18.4.2 分布式应用系统的部署 287
18.4.3 启动服务对象应用 287
第19章 COM与CORBA的对比 289
19.1 COM与CORBA的产生背景 289
19.1.1 COM的产生背景 289
19.1.2 CORBA的产生背景 290
19.2 COM与CORBA的共同点 290
19.2.3 编程语言无关性 291
19.3 COM与CORBA的区别 291
19.3.1 在对象模型方面的区别 291
19.2.2 平台无关性 291
19.2.1 位置无关性 291
19.3.2 在对象的定位方面 292
19.3.3 在对象的持久性管理方面 292
19.3.4 在组件提供的服务方面 292
19.3.5 在异常定义及抛出方式方面 292
19.3.6 在运行平台与组件开发工具方面 293
19.4 小结 293
附录1 OMG IDL保留字 294
附录2 CORBA系统异常类型 295
附录3 接口仓库对象类型 297
附录4 CORBA对象定义 298
附录5 中英文对照 302
附录6 相关互联网资源 304