Corba 用IOR方式实现通信

2023-10-06 22:20
文章标签 实现 方式 通信 ior corba

本文主要是介绍Corba 用IOR方式实现通信,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

源码地址:https://github.com/Foolegend/corbatest

1.创建一个idl接口文件(HelloServer.idl)如下

interface HelloServer{void sayHello(in string name);
};

利用idlj -fall HelloServer.idl进行编译,会得到下面几个文件

2.创建一个HelloServerImpl实现类,实现接口中定义的功能

package com.fod.service;public class HelloServerImpl extends HelloServerPOA{@Overridepublic void sayHello(String name) {System.out.println("Hello ," + name + ".");}
}

3.创建服务端corba启动类HelloTestService如下

package com.fod.service;import org.omg.CORBA.ORB;
import org.omg.CORBA.Policy;
import org.omg.PortableServer.IdAssignmentPolicyValue;
import org.omg.PortableServer.POA;
import org.omg.PortableServer.POAHelper;
import org.omg.PortableServer.ThreadPolicyValue;import java.io.File;
import java.io.FileOutputStream;
import java.io.PrintWriter;
import java.util.Properties;public class HelloTestService {public static void main(String[] args) {// 生成一个ORB,并初始化,这个和Server端一样Properties props = System.getProperties();//配置发布端口和ipprops.put("org.omg.CORBA.ORBInitialPort", "1050");props.put("org.omg.CORBA.ORBInitialHost", "192.168.0.106");System.out.println("ORB initialised\n");try {// Initialize the ORB.ORB orb = ORB.init(args, props);// get a reference to the root POAorg.omg.CORBA.Object obj = orb.resolve_initial_references("RootPOA");POA poaRoot = POAHelper.narrow(obj);// Create policies for our persistent POAPolicy[] policies = {// poaRoot.create_lifespan_policy(LifespanPolicyValue.PERSISTENT),poaRoot.create_id_assignment_policy(IdAssignmentPolicyValue.USER_ID),poaRoot.create_thread_policy(ThreadPolicyValue.ORB_CTRL_MODEL)};// Create myPOA with the right policiesPOA poa = poaRoot.create_POA("HelloServerPOA", poaRoot.the_POAManager(), policies);// Create the servantHelloServerImpl servant = new HelloServerImpl();// Activate the servant with the ID on myPOAbyte[] objectId = "AnyObjectID".getBytes();poa.activate_object_with_id(objectId, servant);// Activate the POA managerpoaRoot.the_POAManager().activate();// Get a reference to the servant and write it down.obj = poa.servant_to_reference(servant);PrintWriter ps = new PrintWriter(new FileOutputStream(new File("server.ior")));ps.println(orb.object_to_string(obj));ps.close();System.out.println("CORBA Server ready...");// Wait for incoming requestsorb.run();}catch(Exception ex) {ex.printStackTrace();}}
}

4.创建corba客户端操作类如下

package com.fod.service;import java.io.FileReader;
import java.io.LineNumberReader;
import java.util.Properties;class HelloClientImpl {private HelloServer target = null;private org.omg.CORBA.ORB orb = null;/*** Constructor for HelloClientImpl**/public HelloClientImpl() throws Exception {initORB(null);}/*** Constructor for HelloClientImpl* @see java.lang.Object#Object()*/public HelloClientImpl(String[] args) throws Exception {initORB(args);}/*** Initialize ORB.** @param args*/public void initORB(String[] args) throws Exception {//设置远程调用ip和端口Properties props = System.getProperties();props.put("org.omg.CORBA.ORBInitialPort", "1050");props.put("org.omg.CORBA.ORBInitialHost", "192.168.0.106");// Initialize the ORBorb = org.omg.CORBA.ORB.init((String[])args, props);// ---- Uncomment below to enable Naming Service access. ----
//        LineNumberReader input = new LineNumberReader(new FileReader("server.ior"));
//        String ior = input.readLine();
//此处的ior串是你环境上server.ior文件中的一串字符org.omg.CORBA.Object obj = orb.string_to_object("IOR:000000000000001449444c3a48656c6c6f5365727665723a312e3000000000010000000000000096000102000000000a3132372e302e312e3100b49100000048afabcb00000000206fe9875200000001000000000000000200000008526f6f74504f41000000000f48656c6c6f536572766572504f4100000000000b416e794f626a656374494414000000020000000100000020000000000001000100000002050100010001002000010109000000010001010000000026000000020002");target = HelloServerHelper.narrow(obj);}/*** Obtain ORB Interface.** @return*/public HelloServer getORBInterface() {return target;}/*** Shutdown ORB.*/public void shutdown() {orb.shutdown(true);}/*** Test driver for HelloClientImpl.* @param args*/public static void main(String[] args) {try {HelloClientImpl test = new HelloClientImpl();test.getORBInterface().sayHello("lifa");//停止test.shutdown();}catch(Exception ex) {ex.printStackTrace();}}
}

5.启动服务端,然后启动客户端,就会看到服务端控制台打印了Hello, lifa

这篇关于Corba 用IOR方式实现通信的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/154253

相关文章

虚拟机与物理机的文件共享方式

《虚拟机与物理机的文件共享方式》文章介绍了如何在KaliLinux虚拟机中实现物理机文件夹的直接挂载,以便在虚拟机中方便地读取和使用物理机上的文件,通过设置和配置,可以实现临时挂载和永久挂载,并提供... 目录虚拟机与物理机的文件共享1 虚拟机设置2 验证Kali下分享文件夹功能是否启用3 创建挂载目录4

linux报错INFO:task xxxxxx:634 blocked for more than 120 seconds.三种解决方式

《linux报错INFO:taskxxxxxx:634blockedformorethan120seconds.三种解决方式》文章描述了一个Linux最小系统运行时出现的“hung_ta... 目录1.问题描述2.解决办法2.1 缩小文件系统缓存大小2.2 修改系统IO调度策略2.3 取消120秒时间限制3

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服