永发信息网

java远程调用接口的原理和范例,谢谢

答案:2  悬赏:10  手机版
解决时间 2021-03-23 03:02
java远程调用接口的原理和范例,谢谢
最佳答案
Java 远程处理
   Java远程方法调用(RMI)提供了Java程序语言的远程通讯功能,这种特性使客户机上运行的程序可以调用远程服务器上的对象,使Java编程人员能够在网络环境中分布操作。
   创建一个简单的Java分布式远程方法调用程序可以按以下几个步骤操作,
  
   一、定义远程接口:
   在 Java 中,远程对象是实现远程接口的类的实例, 远程接口声明每个要远程调用的方法。在需要创建一个远程对象的时候,我们通过传递一个接口来隐藏基层的实施细节,客户通过接口句柄发送消息即可。
   远程接口具有如下特点:
   1) 远程接口必须为public属性。如果不这样,除非客户端与远程接口在同一个包内,否则 当试图装入实现该远程接口的远程对象时,调用会得到错误结果。
   2) 远程接口必须扩展接口java.rmi.Remote。
   3) 除与应用程序本身特定的例外之外,远程接口中的每个方法都必须在自己的throws从句中 声明java.rmi.RemoteException。(或 RemoteException 的父类)。
   4) 作为参数或返回值传递的一个远程对象(不管是直接,还是本地对象中嵌入)必须声明为远 程接口,而不应声明为实施类。

下面是远程接口的定义

[java] view plaincopy
package test;
import java.rmi.Remote;
import java.rmi.RemoteException;
import java.math.BigInteger;

public interface Fib extends Remote {
public int getFib(int n) throws RemoteException;
// public BigInteger getFib(BigInteger n) throws RemoteException;
}

二、实现远程接口:
   远程对象实现类必须扩展远程对象java.rmi.UnicastRemoteObject类,并实现所定义的远程接口。远程对象的实现类中包含实现每个远程接口所指定的远程方法的代码。这个类也可以含有附加的方法,但客户只能使用远程接口中的方法。因为客户是指向接口的一个句柄,而不是它的哪个类。必须为远程对象定义构造函数,即使只准备定义一个默认构造函数,用它调用基础类构造函数。因为基础类构造函数可能会抛出 java.rmi.RemoteException,所以即使别无它用必须抛出java.rmi.RemoteException例外。
   以下是远程对象实现类的声明:

[java] view plaincopy
package test;
import java.math.BigInteger;
import java.rmi.*;
import java.rmi.server.UnicastRemoteObject;

public class FibImp extends UnicastRemoteObject implements Fib {
public FibImp() throws RemoteException {
super();
}

public int getFib(int n) throws RemoteException {
return n+2;
}

}

三、编写服务器类:
   包含 main 方法的类可以是实现类自身,也可以完全是另一个类。下面通过RmiSampleServer 来创建一个远程对象的实例,并通过java.rmi.registry.LocateRegistry类的createRegistry 方法从指定端口号启动注册服务程序,也可以通过执行 rmiregistry 命令启动注册服务程序,注册服务程序的缺省运行端口为 1099。必须将远程对象名字绑定到对远程对象的引用上: Naming.rebind("//localhost:8808/SAMPLE-SERVER" , Server);
   以下是服务器类的声明:

[java] view plaincopy
package test;
import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
public class FibonacciServer {

public static void main(String[] args) {
try {
LocateRegistry.createRegistry(8804);
FibImp f = new FibImp();

// 注册到 registry 中
Naming.rebind("//localhost:8804/SAMPLE-SERVER", f);
System.out.println("fib server ready");

} catch (RemoteException re) {
System.out.println("Exception in FibonacciImpl.main: " + re);
} catch (MalformedURLException e) {
System.out.println("MalformedURLException " + e);
}
}
}

四、编写使用远程服务的客户机类:
   客户机类的主要功能有两个,一是通过Naming.lookup方法来构造注册服务程序 stub 程序实例,二是调用服务器远程对象上的远程方法。
   以下是客户端类的声明:

[java] view plaincopy
package testClient;

import test.Fib;
import java.math.BigInteger;
import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.NotBoundException;
import java.rmi.RemoteException;
public class FibClient {

public static void main(String[] args) {
String url = "//localhost:8804/SAMPLE-SERVER";
try {

Fib calc = (Fib) Naming.lookup(url);
for (int i = 0; i < 10; ++i) {
int f = calc.getFib(i);
System.out.println(f);
}
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (RemoteException e) {
e.printStackTrace();
} catch (NotBoundException e) {
e.printStackTrace();
}
}
}
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
一般的披萨多少钱一份
求wuyanzhiyue1到5全集
车子停在路边早上被洒水车溅了一身泥水
联通如意通-河北18元校园流量王2016是预付费
我于7月8日下午三点左右,在湘CXD705的士上面
如图所示,a、b是多孔石墨电极。某同学按图示
(she/her)name is lucy应该选那个?
2015年时尚芭莎慈善夜哪些明星参加
祝福研究生毕业贺词,孩他爸研究生毕业祝福语
谈谈三国三大上将-----潘凤、蔡阳、刑道荣
他们三个谁好看
泰国OG护肤品,有这种牌子的护肤产品吗
我在惠州仲凯陈江的地方。想去广州东火车站?
求:电视剧仙鹤神针在线免费观看地址
镇魔曲手游星术天罡技巧分享 星术天罡怎么打
推荐资讯
东赵村村地址在什么地方,想过去办事
把A、B、C、D四种物质放在密闭容器中,在一定
爱因斯坦移居柏林阅读答案
为什么早上想睡个懒觉都睡不着呢
上午10时()分的时候,时针和分真能重合 ?
买故宫博物院复制的书画藏品物有所值吗
如图,C为线段AE上一动点(不与点A,E重合)
纱布尿布清洗后会掉棉屑吗?
怎么找回魅族FIYME用户密码
在图书馆借了一本张爱玲的<倾城之恋>,可是目
怎么关闭微信红包声音,微信红包有声音怎么关
失眠的唯美句子,失眠下雨天形容伤感的句子
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?