当前位置:首页 > 开发 > 编程语言 > Java > 正文

JavaRMI学习笔记1

发表于: 2014-06-04   作者:wang吖   来源:转载   浏览:
摘要: 通过Java Rmi 的远程方法调用返回一个对象列表,代码如下:   1、Server服务接口 import java.rmi.Remote; import java.rmi.RemoteException; import java.util.List; //须继承Romote类 public interface IStuService extends Remote {

通过Java Rmi 的远程方法调用返回一个对象列表,代码如下:

 

1、Server服务接口

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

//须继承Romote类
public interface IStuService extends Remote {

	public List<Student> getStudet() throws RemoteException;
}

 

2、Server服务接口实现类

import java.rmi.RemoteException;
import java.rmi.server.RMIClientSocketFactory;
import java.rmi.server.RMIServerSocketFactory;
import java.rmi.server.UnicastRemoteObject;
import java.util.ArrayList;
import java.util.List;

//须继承UnicastRemoteObject类  同时要重写构造方法  由于父类的构造方法抛异常了
public class StuServiceImpl extends UnicastRemoteObject implements IStuService {

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

	public StuServiceImpl(int i, RMIClientSocketFactory rmiclientsocketfactory,
			RMIServerSocketFactory rmiserversocketfactory)
			throws RemoteException {
		super(i, rmiclientsocketfactory, rmiserversocketfactory);
	}

	public StuServiceImpl(int i) throws RemoteException {
		super(i);
	}

	@Override
	public List<Student> getStudet() throws RemoteException {
		List<Student> list = new ArrayList<Student>();

		Student s1 = new Student();
		s1.setId(1);
		s1.setName("xxx");

		Student s2 = new Student();
		s2.setId(2);
		s2.setName("yyy");

		list.add(s1);
		list.add(s2);

		return list;
	}

}

 

3、Server服务发布类

import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;

public class RmiServer {

	public static void main(String[] args) {
		try {
			IStuService ss = new StuServiceImpl();

			// 注册一个通讯端口
			LocateRegistry.createRegistry(6666);

			// 注册一个通讯路径
			Naming.rebind("rmi://127.0.0.1:6666/service", ss);
			System.out.println("Service Start!");
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

 

4、Entity实体类(注意:实体类必须实现Serializable接口)

public class Student implements java.io.Serializable {

	private int id;
	private String name;

	public int getId() {
		return id;
	}

	public void setId(int id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

}

 

5、Client客户端

import java.rmi.Naming;
import java.util.List;

public class Client {

	public static void main(String[] args) {

		try {
			// 此处不能强制转换为接口的实现类
			IStuService ss = (IStuService) Naming
					.lookup("rmi://127.0.0.1:6666/service");

			List<Student> list = ss.getStudet();

			for (Student stu : list) {
				System.out.println(stu.getId() + "--------" + stu.getName());
			}
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}

 

 

JavaRMI学习笔记1

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
JavaRMI   RMI(Remote Method Invocation,远程方法调用)是用Java在JDK1.1中实现的,它大大增强
1登录mysql命令行实用工具 mysql -uroot -proot -u 指定用户名 -p 指定密码 -h 指定服务器IP或者域
nginx在启动后,会有一个master进程和多个worker进程。master进程主要用来管理worker进程,包含:接
准备工作,下载稳定版本的struts2包 导入必需的最小jar包 Commons-logging-1.0.4.jar Freemarker-2.
HelloWorld实例(快速上手) struts2.1.8 新建一个web项目, 按照目录结构 添加struts.xml&所用到的ja
CLR 介绍 从Code 到Module C# 代码被编译器拿去编译生成IL,32位的生成PE32 Header,64位 生成PE32+
1、 在html中嵌入在 <script language="javascript"> .......这中间是java script代码 </s
1、 在html中嵌入在 <script language="javascript"> .......这中间是java script代码 </s
Linux 学习笔记[1] 1.Linux目录结构 与windows不同,linux 的部分目录结构如下: 其中/为所有目录的
#include <stdlib.h> #include <gtk/gtk.h> int main(int argc,char *argv[]) { GtkWid
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号