Java-CORBA
本文HelloCorba参考 Getting Started with JavaTM IDL
说在前面
Java TM IDL is a technology for distributed objects--that is, objects interacting on different platforms across a network. Java IDL enables objects to interact regardless of whether they're written in the Java programming language or another language such as C, C++, COBOL, or others.
Common Object Request Brokerage Architecture (CORBA):公共对象请求代理体系结构
Object Request Broker:对象请求代理
This figure shows how a one-method distributed object is shared between a CORBA client and server to implement the classic "Hello World" application.

HelloCorba说明
1. 新建文件Hello.idl
内容为:
module HelloApp
{
  interface Hello
  {
    string sayHello();
    oneway void shutdown();
  };
};
2. 输入命令
idlj -fall Hello.idl
安装了jdk就会有idlj,idlj跟javac是在同一个目录的;
如果出现异常java.io.FileNotFoundException: hello.idl (No such file or directory),可尝试命令 idlj -fall ./Hello
这样我们得到一个文件夹,里面有6个文件,这6个文件是什么来的呢?我们先接着往下看
_HelloStub.java
Hello.java
HelloHelper.java
HelloHolder.java
HelloOperations.java
HelloPOA.java
HelloOperations.java里面才上我们真正需要的操作,我们需要实现的是抽象类HelloPOA,其实就是实现接口HelloOperations
3. HelloServer
代码在这:
https://docs.oracle.com/javase/1.5.0/docs/guide/idl/tutorial/GSserver.html
4. HelloClient
代码在这:
https://docs.oracle.com/javase/1.5.0/docs/guide/idl/tutorial/GSapp.html
5. 运行
参照:https://docs.oracle.com/javase/1.5.0/docs/guide/idl/tutorial/GScompile.html
作者运行环境为:macos:10.13.4 (17E199) JDK1.8 iterm2
1.启动orbd
orbd -ORBInitialPort 1050 -ORBInitialHost localhost&
(末尾的&是指以守护线程的方式启动)
2.先开始server
java HelloServer -ORBInitialPort 1050 -ORBInitialHost localhost&
3.最后开启client
java HelloClient -ORBInitialPort 1050 -ORBInitialHost localhost
4.结果
Hello world !!
ToDoListCorba 设计思路
写两个module
定义操作
module centerModule{
  interface CenterService{
      boolean login( in string name, in string password);
      boolean register(in string name,in  string password);
      boolean save();
  };
};
定义用户操作
   module userModule{
        interface UserService{
            boolean add(in string startTime,in string endTime,in string item);
	        string query(in string startTime,in string endTime);
	        boolean delete(in string item);
	        boolean clear();
	        string show();
	        boolean save(in string name);
	        void init(in string name);
        };
};
在上面两个文件所在的目录使用idlj命令编译,输入命令idlj -fall yourname.idl
ok,成功得到下面文件
_OperationServiceStub.java
OperationService.java
OperationServiceHelper.java
OperationServiceHolder.java
OperationServiceOperations.java
OperationServicePOA.java
同理,我们可以得到
_UserServiceStub.java
UserService.java
UserServiceHelper.java
UserServiceHolder.java
UserServiceOperations.java
UserServicePOA.java
实现2个POA
所有的操作都源于service,server端暴露的也只有service的接口,其余的实现都是隐蔽的,所以,关键是实现好service。
CenterService实现的功能有:登录、注册、保存
有一个成员变量Map<String,User>
- 所有的注册用户使用一个Map<String,User>来管理,登录注册都是对Map<String,User>的操作
- 保存是将Map<String,User>序列化到本地的data/centerService文件,通过读取data/centerService文件来反序列化Map<String,User>,实现数据的持久化
UserService实现的功能有:添加、查询、删除、清除、保存。有一个成员变量List<Item>
- CURD操作是针对List<Item>来展开的
- 保存是将List<Item>序列化到本地的data/userName文件,为每一个注册的用户都独立保存List<Item>,通过读取data/userName文件来反序列化List<Item>
server
ToDoListServer是本程序的server,作用有2个:
- 第一个作用是提供CenterService,用于登录注册
- 第二个作用是为进行登录、注册操作的用户提供userService。
client
ToDoListClient是是本程序的client,作用是获取服务端的CenterService为用户提供登录、注册功能,然后为注册、登录成功的用户提供UserService功能
基本原理分析
基本思路跟RPC是一样的,首先在服务端新建一个对象,注册好了,然后再客户端获得这个对象的引用,当调用这个引用的方法的时候,实际上会调用到客户端的对象,然后再把结果返回给客户端的对象引用。
在ToDoListServer里面,通过COBRA将centerServiceImpl对象绑定到COBRA的根命名上下文(root naming context),它有个名字叫做NameService,然后我们给centerServiceImpl对象取个名字,就叫centerService,然后把CenterServiceImpl绑定到NameService下面。后面我们就可以通过centerService获取到我们预先绑定的centerServiceImpl对象了。
具体实现方案看代码ToDoListServer.init()和ToDoListClient.init
演示流程
- 首先必须启动orbd,命令:orbd -ORBInitialPort 1050 -ORBInitialHost localhost&
- 启动ToDoListServer
  
- 启动ToDoListClient
  
- 注册账号hello3 ,密码hello3
  
- 添加一些数据,时间的输入要求不含有中文
  
- 开始查询,查询根据开始时间和结束时间的范围查询
  
- 删除看看
  
- 重启client,server,再次登录hello3账号
  
源码链接
最后
感谢看到最后的你,喜欢文章就点个再走啦 -
Java-CORBA的更多相关文章
- java 11 移除的一些其他内容,更简化的编译运行程序,Unicode 10,移除了不太使用的JavaEE模块和CORBA技术,废除Nashorn javascript引擎,不建议使用Pack200 相关api
		移除的一些其他内容 移除项 移除了com.sun.awt.AWTUtilities 移除了sun.misc.Unsafe.defineClass, 使用java.lang.invoke.MethodH ... 
- java的访问控制(包、访问修饰符、修饰符)
		一. java的类包 编写好一个源程序后,首先要执行javac命令进行编译源文件,并生成与源文件同名后缀为“.class”的字节码文件(类文件),该类文件与源文件默认在同一个目录中.该类文件是 ... 
- Java 9 揭秘(8. JDK 9重大改变)
		Tips 做一个终身学习的人. 在本章,主要介绍以下内容: 新的JDK版本控制方案是什么 如何使用Runtime.Version类解析JDK版本字符串 JDK JRE 9的新目录布局是什么 JDK 9 ... 
- 使用非java代码编程
		使用非JAVA代码 JAVA语言及其标准API(应用程序编程接口)应付应用程序的编写已绰绰有余.但在某些情况下,还是必须使用非JAVA编码.例如,我们有时要访问操作系统的专用特性,与特殊的硬件 ... 
- Java 9 模块化(Modularity)
		JDK9的发布一直在推迟,终于在2017年9月21日发布了.下面是JDK9的几个下载地址: JDK9.0.1 Windows-x64下载地址 Oracle Java 官网下载地址 OpenJDK 9官 ... 
- JavaSE入门学习17:Java面向对象之package(包)
		一Java包(package) 为了更好地组织类,Java提供了包机制,用于差别类名的命名空间. 包的作用: A把功能类似或相关的类或接口组织在 ... 
- 【java 理论篇 2】J2EE的13种规范
		导读:看完了J2EE的视频,没有什么技术实践,现在就从理论上说明一下J2EE的13种规范,以及现在的自己对它的一个理解.可能会有偏差,但是,算是做为目前的一个记录. 一.13种规范 1.1.JDBC( ... 
- java 9 Spring Cloud @EnableEurekaServer   javax.xml.bind.JAXBContext not present
		java 9 Spring Cloud @EnableEurekaServer javax.xml.bind.JAXBContext not present jdk 8下面还可以正常启动,jdk9 ... 
- java.lang.TypeNotPresentException: Type javax.xml.bind.JAXBContext not present解决方案
		因为JAXB-API是java ee的一部分,在jdk9中没有在默认的类路径中: java ee api在jdk中还是存在的,默认没有加载而已,jdk9中引入了模块的概念,可以使用 模块命令--add ... 
- Java 11   New   Features
		前言 北京时间 2018年9 月 26 日,Oracle 官方宣布 Java 11 正式发布.这是 Java 大版本周期变化后的第一个长期支持版本,非常值得关注.从官网即可下载, 最新发布的 Java ... 
随机推荐
- 郭盛华:DNS新漏洞可使黑客可以发起大规模DDoS攻击
			近日,知名网络黑客安全专家.东方联盟创始人郭盛华微博披露了有关影响DNS协议的新缺陷的详细信息,该缺陷可被利用来发起放大的大规模分布式拒绝服务(DDoS)攻击,以击倒目标网站.该漏洞称为NXNSAtt ... 
- jchdl - GSL实例 - Assign
			https://mp.weixin.qq.com/s/MtHR3iolPd5VQq6AUE-JPg Assign是一个节点,把输入线直接赋值给输出线.在转换成Verilog时,这种类型的节点会直接 ... 
- 【zookeeper】安装教程文档需下载
			请查看文件https://download.csdn.net/download/qq_42158942/11846847 zookeeper的作用 • ZooKeeper 是一个开源的分布式协调服务, ... 
- MAVEN添加本地仓库和注意事项!
			将jer包加载本地仓库导命令 注意:电脑配置了maven的环境变量, 安装指定文件到本地仓库命令:mvn install:install-file -Dfile= : 指定jar文件路径与 ... 
- 程序员的脑袋系列---利用ffmpeg命令提取音频
			今日各大播放器的版权控制越来越严格.导致很多歌曲无法听,但是MV却可以听.这样很蛋疼有木有? 然而,我们可以利用ffmpeg工具提取MV的音频,比如做成MP3格式,这样就可以听了.--哈哈(邪恶地笑) ... 
- Java实现 LeetCode 553 最优除法(思路问题)
			553. 最优除法 给定一组正整数,相邻的整数之间将会进行浮点除法操作.例如, [2,3,4] -> 2 / 3 / 4 . 但是,你可以在任意位置添加任意数目的括号,来改变算数的优先级.你需要 ... 
- Java实现 LeetCode 86 分割链表
			86. 分隔链表 给定一个链表和一个特定值 x,对链表进行分隔,使得所有小于 x 的节点都在大于或等于 x 的节点之前. 你应当保留两个分区中每个节点的初始相对位置. 示例: 输入: head = 1 ... 
- Java实现 洛谷 P1487 陶陶摘苹果(升级版)
			题目描述 又是一年秋季时,陶陶家的苹果树结了n个果子.陶陶又跑去摘苹果,这次她有一个a公分的椅子.当他手够不着时,他会站到椅子上再试试. 这次与NOIp2005普及组第一题不同的是:陶陶之前搬凳子,力 ... 
- JVM 由哪些部分组成?
			JVM 由哪些部分组成? 解析:这是对 JVM 体系结构的考察 答:JVM 的结构基本上由 4 部分组成: 类加载器,在 JVM 启动时或者类运行时将需要的 class 加载到 JVM 中 执行引擎, ... 
- java实现第六届蓝桥杯分机号
			分机号 X老板脾气古怪,他们公司的电话分机号都是3位数,老板规定,所有号码必须是降序排列,且不能有重复的数位.比如: 751,520,321 都满足要求,而, 766,918,201 就不符合要求. ... 
