RMI编程示例

本文介绍了一种Java远程方法调用(RMI)的实现方法,包括客户端和服务端的代码编写过程,以及如何生成stub文件。同时,还提供了解决常见问题的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.首先编写客户端和服务端以及算法的代码。代码如下:

(1)接口代码

package com.wonder.rmi;

import java.rmi.Remote;
import java.rmi.RemoteException;
import java.util.List;

public interface RMIOperate extends Remote {
public double add(double x,double y) throws RemoteException;
public double minus(double x,double y) throws RemoteException;
public double add(List l) throws RemoteException;
}

(2)接口的算法实现

package com.wonder.rmi.server;

import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
import java.util.List;

import com.wonder.rmi.RMIOperate;

public class OperateImpl extends UnicastRemoteObject implements RMIOperate {

public OperateImpl() throws RemoteException {
super();
}

/**
*
*/
private static final long serialVersionUID = 1L;

public double add(double x, double y) throws RemoteException {
double z=x+y;
return z;
}

public double minus(double x, double y) throws RemoteException {
double z=x-y;
return z;
}

public double add(List l) throws RemoteException {

return Double.parseDouble(String.valueOf((Double)l.get(0) + (Double)l.get(1)));
}

}
(3)server端程序

package com.wonder.rmi.server;

import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;


public class RMIServer {

/**
* @param args
*/
public static void main(String[] args) {
try {
OperateImpl o = new OperateImpl();
System.out.println("Server is Starting...");
LocateRegistry.createRegistry(7099); // 这个端口应该和绑定的端口一样,如果不指定,默认的端口是1099
Naming.rebind("rmi://192.168.71.214:7099/RMIOperate",o); // 这个端口和上面的端口一样
System.out.println("Waiting RMI client Invoke ...");
} catch (RemoteException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

}

}


2.客户端程序

package com.wonder.rmi.client;

import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.NotBoundException;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import java.util.ArrayList;
import java.util.List;

import com.wonder.rmi.RMIOperate;

public class RMIClient {

/**
* @param args
*/
@SuppressWarnings({"unchecked","unchecked"})
public static void main(String[] args) {
String host = "192.168.71.214";
try {
// 调用方式1
Registry reg = null;
reg = LocateRegistry.getRegistry("192.168.71.214",7099);
RMIOperate rmiObj = (RMIOperate) reg.lookup("RMIOperate");

// 调用方式2
RMIOperate rmiObj1 = (RMIOperate) Naming.lookup("rmi://192.168.71.214:7099/RMIOperate"); //要查找远程服务器的端口

double x = 1;
double y = 2;
List l = new ArrayList(2);
l.add(0,Double.valueOf("123"));
l.add(1,Double.valueOf("456"));

double z = rmiObj.add(x,y);
System.out.println("add="+z);
double w = rmiObj.minus(x,y);
System.out.println("minus="+w);
double _a = rmiObj.add(l);
System.out.println("add list="+_a);
} catch (RemoteException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NotBoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

}

}


3.生成stub

c:/> java weblogic.rmic com.wonder.rmi.server.OperateImpl

为了方便测试,打成jar包,放入到startWebLogic.cmd的路径中

4.如果是在代码中调用了LocateRegistry,则不用在命令提示符窗口启动rmregistry命令

5.设置weblogic的启动类,com.wonder.rmi.server.RMIServer。启动weblogic不出错误就可以了。

二。常见的问题

1.如果是出现连接拒绝的问题,检查rmi注册是否正常启动。并且绑定的地址以及端口正确。

2.如果出现找不到stub类的情况,请检查是否使用rmic生成了相应的stub类。另外还可以检查一下是否正确设置的端口。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值