一.实验目的 1.掌握组件化开发的概念,了解CORBA模型及ORB机制; 2.掌握CORBA组件编程方法。 二、实验内容 步骤: 1.配制环境JDK环境。 2.编写编译IDL接口。 3.编写编译服务端程序。 4.编写编译客户端程序。 5.运行测试与调试。 6.完成报告。 三、实验内容 题目1.Java版CORBA程序1——HelloWorld 题目2.JAVA版CORBA程序2——Counter 四、题目分析 CORBA通过IDL接口定义语言,是一种异构平台下的与语言无关的对象互操作模型。ORB是CORBA体系结构的核心,使得客户应用程序能调用远端对象方法的一种机制。 五、运行结果 题目1.Java版CORBA程序1——HelloWorld 要求编写实现显示“Hello,World!+班级+中文姓名”字符串。
1.启动名字服务器:X:\corba >tnameserv -ORBInitialPort 1060 2.启动服务端程序:X:\corba >java HelloWorldServer -ORBInitialPort 1060 3.启动客户端程序:X:\corba >java HelloWorldClient -ORBInitialPort 1050 在编写并编译完IDL接口HelloWorld.idl后生成sample包 编写并编译服务端程序和客户端程序: HelloWorldServer.java HelloWorldClient.java 题目2.JAVA版CORBA程序2——Counter 要求:编写实现连加、连减和加减混合等数学++/- -运算,并进行测试 1.启动名字服务器:X:\corba >tnameserv -ORBInitialPort 1070 2.启动服务端程序:X:\corba >java Server -ORBInitialPort 1070 3.启动客户端程序:X:\corba >java Client -ORBInitialPort 1070 编写并编译完IDL接口counter.idl出现counterAPP 编写并编译对象实现代码:CounterImpl.java 编写并编译服务端程序: Server.java 编写并编译客户端程序: Client.java 六、CORBA模型分析 当客户程序要调用远程对象上的方法时,首先要得到这个远程对象的引用,之后就可以像调用本地方法一样调用远程对象的方法。当发出一个调用时,实际上ORB会截取这个调用(通过客户Stub完成),ORB还负责将调用的名字、参数等变成标准的方式通过网络传输到服务器端,并通过Unmarshaling的过程,传到正确的对象上,服务器对象完成处理后,ORB通过同样的方式Unmarshaling将结果返回给客户。 具体实现过程: HelloWorld程序中,首先定义接口,在接口中定义要远程调用的方法。其次实现接口,为了实现远程调用,每个实例化都要经过export和发布两个流程。 然后写Corba Server,完成发布任务。Server启动后,生成POA,告诉POA他所能提供的服务即Servant。最后测试客户端,用于测试上面提供的接口,Client通过NameService查询获得要访问的对象的引用ORB。 组件结构图 (1) (2) 七、实验总结 出现的问题:刚开始编译IDL接口时并没有成功,问题出在环境变量没有配置好。 还有之后启动客户端和服务端出现无法加载的主类,问题出在没有将Java文件编译成.class文件。 总结:ORB是CORBA体系结构的核心,它是一种功能,具备以下能力: 1.对象定位(根据对象引用定位对象的实现); 2.对象定位后,确信Server能接受请求; 3.将客户端请求通过方式重新定位到服务器对象上; 4.如果需要,将结果以同样的方式返回。 IDL是接口定义语言,仅仅定义接口,而不定义实现。
