rmi协议 java调用c_Java RMI协议远程方法调用(RPC)

参考:java

RMI是相似RPC的一种远程方法调用协议,比RPC类型的WebService更简单,也能够跨进程访问this

先来建立一个model或者javaBean,注意,该类必须实现序列化Serializable.net

public class Person implements Serializable {

private int id;

private String name;

private int age;

public void setId(int id) {

this.id = id;

}

public int getId() {

return id;

}

public void setName(String name) {

this.name = name;

}

public String getName() {

return name;

}

public void setAge(int age) {

this.age = age;

}

public int getAge() {

return age;

}

}

调用接口

code

//此为远程对象调用的接口,必须继承Remote类

public interface PersonService extends Remote {

public List GetList() throws RemoteException;

}

实现接口,注意必须继承UnicastRemoteObject 对象

public class PersonServiceImpl extends UnicastRemoteObject implements PersonService {

public PersonServiceImpl() throws RemoteException {

super();

// TODO Auto-generated constructor stub

}

@Override

public List GetList() throws RemoteException {

// TODO Auto-generated method stub

System.out.println("Get Person Start!");

List personList=new LinkedList();

Person person1=new Person();

person1.setAge(25);

person1.setId(0);

person1.setName("Leslie");

personList.add(person1);

Person person2=new Person();

person2.setAge(25);

person2.setId(1);

person2.setName("Rose");

personList.add(person2);

return personList;

}

}

Server端blog

public class RMIServer{

public static void main(String[] args)

{

try {

PersonService personService=new PersonServiceImpl();

//注册通信端口

LocateRegistry.createRegistry(6600);

//注册通信路径

Naming.rebind("rmi://127.0.0.1:6600/PersonService", personService);

System.out.println("Service Start!");

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

客户端继承

public class RMIClient {

public static void main(String[] args){

try{

//调用远程对象,注意RMI路径与接口必须与服务器配置一致

PersonService personService=(PersonService)Naming.lookup("rmi://127.0.0.1:6600/PersonService");

List personList=personService.GetList();

for(Person person:personList)

{

System.out.println("ID:"+person.getId()+" Age:"+person.getAge()+" Name:"+person.getName());

}

}catch(Exception ex){

ex.printStackTrace();

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值