java分布式 rmi_java RMI分布式应用程序 (一个简单的RMI的例子)

[java]代码库package hello;

public interface Hello extends java.rmi.Remote {

//rmi应用程序必须继承自java.rmi.Remote

String sayHello() throws java.rmi.RemoteException ;

//定义可以远程调用的接口

}

//server方程序,定义HelloImpl类实现Hello接口:

package hello;

import java.rmi.*;

import java.rmi.server.UnicastRemoteObject;

public class HelloImpl extends UnicastRemoteObject implements Hello

//实现Hello接口

{

private String name;

public HelloImpl (String s ) throws java.rmi.RemoteException {

super(); //调用父类的构造函数

name = s;

}

public String sayHello() throws RemoteException {

return "Hello world!"; //实现Hello接口定义的方法

}

public static void main ( String args []) {

System.setSecurityManager ( new RMISecurityManager() );

//设置RMI程序需要的安全策略

try {

HelloImpl obj = new HelloImpl ("HelloServer");

//生成一个HelloImpl的实例

Naming.rebind ("HelloServer", obj);

//将这个实例绑定到一个名字上

System.out.println ("HelloImpl created and bound in the registry to the name HelloServer");

} catch (Exception e) {

System.out.println ("HelloImpl.main: an exception occured:");

e.printStackTrace(); //产生异常的话,打印出出错信息

}

}

}

//server方生成一个远程对象并和一个可和客户对话的名称"HelloServer"绑定。Client端可以根据该名称寻找相应的远程对象,进而调用其远程方法。

//client方程序

package hello;

import java.rmi.*; public class HelloClient {

public static void main (String args[]) {

System.setSecurityManager (new RMISecurityManager() );

//设置RMI需要的安全策略

try {

Hello obj = (Hello) Naming.lookup ("HelloServer");

//从服务端获得一个Hello的远程对象

String message = obj.sayHello();

//远程调用Hello的方法

System.out.println (message);

//将输出结果打印

} catch (Exception e) {

System.out.println ("Hello client : an exception occured");

e.printStackTrace(); //若有异常,输出异常信息

}

}

}

694748ed64b9390909c0d88230893790.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值