`
log_cd
  • 浏览: 1101651 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论
阅读更多
   RMI限java之间,且使用Stream 技术(serialize)传输。WebService是通过XML来传输数据,可用http等协议因此可在异构系统间传递,并且可以穿过防火墙,可在公网上远程调用。
(1)远程调用接口

import java.rmi.Remote;
import java.rmi.RemoteException;
public interface ComputerEngineRemote extends Remote {
    public Object excuteTask(Task task) throws RemoteException;

}


(2)远程调用接口实现

public class ComputerEngine extends UnicastRemoteObject implements
        ComputerEngineRemote {

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

	protected ComputerEngine() throws RemoteException {
        super();
    }

    public Object excuteTask(Task task) throws RemoteException {
        return task.excute();
    }

}


(3)定义业务接口

public interface Task extends Serializable {
    Object excute();

}


(2)业务接口实现

public class TaskImpl implements Task {

	private static final long serialVersionUID = 1L;

	public Object excute() {
        return "Successful!";
    }

}


(4)将远程对象注册到 RMI 的注册表

public class Bootstrap {

/*  "引导"过程(Bootstrap)。引导程序负责创建和注册远程对象。*/
public static void main(String[] args) throws Exception {
         String name="ComputerEngine";
        //System.setProperty("java.rmi.server.hostname","172.31.3.33");
        //System.setProperty( "java.security.policy", "client.policy" );
        //System.setSecurityManager(new java.rmi.RMISecurityManager());
    	LocateRegistry.createRegistry(1099);     
    	ComputerEngine server = new ComputerEngine(); 
    	Naming.rebind("rmi://127.0.0.1:1099/ComputerEngine", server); 
    	System.out.println("Ready to accept tasks"); 

    	}
}


(5)远程调用接口

public class Client {

    public static void main(String[] args) throws Exception {
        String name="rmi://127.0.0.1:1099/ComputerEngine";
        try{
           //定义接口
           ComputerEngineRemote engineRemote=(ComputerEngineRemote) Naming.lookup(name);
           System.out.println(engineRemote.excuteTask(new TaskImpl()));
           }catch(ConnectException e){
    	   e.printStackTrace();
    	   System.out.println("No listener!");
       }

    }

}


(6)java.policy

permission java.net.SocketPermission "127.0.0.1:1099","connect,resolve";

permission   java.security.AllPermission;
  
   Java应用程序环境的安全策略,详细说明了对于不同的代码所拥有的不同资源的许可,它由一个Policy对象来表达。为了让applet(或者运行在   SecurityManager下的一个应用程序)能够执行受保护的行为,例如读写文件,applet(或   Java应用程序)必须获得那项操作的许可,安全策略文件就是用来实现这些许可。
grant   {    
  //对系统和用户目录“读”的权限    
  permission   java.util.PropertyPermission   “user.dir",   “read";    
  permission   java.util.PropertyPermission   “user.home",   “read";    
  permission   java.util.PropertyPermission   “java.home",   “read";    
  permission   java.util.PropertyPermission   “java.class.path",   “read";    
  permission   java.util.PropertyPermission   “user.name",   “read";    
   
  //对线程和线程组的操作权限    
  permission   java.lang.RuntimePermission   “modifyThread";    
  permission   java.lang.RuntimePermission   “modifyThreadGroup";    
   
  //操作Socket端口的各种权限    
  permission   java.net.SocketPermission   “-",   “listen";    
  permission   java.net.SocketPermission   “-",   “accept";    
  permission   java.net.SocketPermission   “-",   “connect";    
  permission   java.net.SocketPermission   “-",   “read";    
  permission   java.net.SocketPermission   “-",   “write";    
   
  //读写文件的权限    
  permission   java.io.FilePermission   “-",   “read";    
  permission   java.io.FilePermission   “-",   “write";    
   
  //退出系统的权限,例如System.exit(0)    
  permission   java.lang.RuntimePermission   “exitVM";    
};    

(7)远程调用,得到图片文件

Remote:
public Object excute() {
		String inputFile="D:/images/img.bmp";
		FileInputStream source=null;
        ByteArrayOutputStream bos = new ByteArrayOutputStream();
		try {
			source = new FileInputStream(new File(inputFile));
		    int bytes_read;
		    byte[] buffer = new byte[1024];
		    while (true) {
		        bytes_read = source.read(buffer);
		        if (bytes_read == -1) {
		          break;
		        }
		        bos.write(buffer, 0, bytes_read);
		    }
	        byte[] data = bos.toByteArray();
	        bos.close();
	        bos = null;
	        return data;
        }catch(Exception e){
            
        }finally{
            if(bos != null){
                try {
					bos.close();
				} catch (IOException e) {
					e.printStackTrace();
				}
                bos = null;
            }
        }
        return null;
}


Client:

public static void main(String[] args) throws Exception {
        String name="rmi://127.0.0.1:1099/ComputerEngine";
       try{
    	   ComputerEngineRemote engineRemote=(ComputerEngineRemote) Naming.lookup(name);
    	   File outputFile = new File("D:/images/receive.bmp");
		   FileOutputStream target = new FileOutputStream(outputFile);
		   target.write((byte[])engineRemote.excuteTask(new TaskImpl()));
		   System.out.println("OK!");
       }catch(ConnectException e){
    	   e.printStackTrace();
    	   System.out.println("No listener!");
       }
}
分享到:
评论
1 楼 Motte2010 2012-03-08  
远程对象注册到 RMI 的注册表  这步报错  楼主没有遇到这问题?
java.rmi.StubNotFoundException: Stub class not found: server.TaskRemoteImp_Stub; nested exception is: 
	java.lang.ClassNotFoundException: server.TaskRemoteImp_Stub
	at sun.rmi.server.RemoteProxy.getStub(RemoteProxy.java:98)
	at sun.rmi.server.RemoteProxy.getStub(RemoteProxy.java:55)
	at sun.rmi.server.UnicastServerRef.setSkeleton(UnicastServerRef.java:179)
	at sun.rmi.server.UnicastServerRef.exportObject(UnicastServerRef.java:142)
	at sun.rmi.server.UnicastServerRef.exportObject(UnicastServerRef.java:129)
	at java.rmi.server.UnicastRemoteObject.exportObject(UnicastRemoteObject.java:275)
	at java.rmi.server.UnicastRemoteObject.exportObject(UnicastRemoteObject.java:178)
	at java.rmi.server.UnicastRemoteObject.<init>(UnicastRemoteObject.java:75)
	at java.rmi.server.UnicastRemoteObject.<init>(UnicastRemoteObject.java:61)
	at server.TaskRemoteImp.<init>(TaskRemoteImp.java:13)
	at rmiMain.main(rmiMain.java:15)
Caused by: java.lang.ClassNotFoundException: server.TaskRemoteImp_Stub
	at java.net.URLClassLoader$1.run(URLClassLoader.java:199)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.net.URLClassLoader.findClass(URLClassLoader.java:187)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:289)
	at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:274)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:235)
	at sun.rmi.server.RemoteProxy.loadClassFromClass(RemoteProxy.java:191)
	at sun.rmi.server.RemoteProxy.getStub(RemoteProxy.java:93)
	... 10 more
Exception in thread "main" 

是按照楼主所写的那样操作的啊

相关推荐

    基于JAVA RMI的聊天室

    **基于JAVA RMI的聊天室** Java Remote Method Invocation(RMI)是Java平台提供的一种用于在分布式环境中调用远程对象的方法。在这个“基于JAVA RMI的聊天室”项目中,开发者利用RMI技术构建了一个简单的多用户...

    java RMI技术实现的网络聊天室

    Java RMI(Remote Method Invocation)技术是Java平台中用于分布式计算的一种机制,它允许一个Java对象调用远程计算机上的另一个Java对象的方法。在本案例中,“java RMI技术实现的网络聊天室”是一个使用RMI构建的...

    javaRMI反序列化漏洞验证工具

    Java RMI(Remote Method Invocation,远程方法调用)是一种Java技术,允许在分布式环境中执行远程对象的方法。这个技术的核心是序列化和反序列化过程,它使得对象可以在网络上进行传输。然而,这个特性也可能引入...

    java rmi java rmi

    根据提供的文件信息,我们可以深入探讨Java RMI(Java Remote Method Invocation)的相关知识点,包括其概念、原理、体系结构以及一个具体的示例。 ### RMI的概念 RMI是一种Java技术,它允许开发者创建分布式应用...

    java RMI实现代码

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许在不同的Java虚拟机之间进行远程对象的调用。RMI使得开发者可以像调用本地对象一样调用网络上的对象,极大地简化了...

    JavaRMI快速入门

    Java Remote Method Invocation(Java RMI)是Java编程语言中用于在网络间进行远程对象调用的技术。它是Java平台的标准部分,允许程序员在分布式环境中调用对象的方法,就像它们在同一台计算机上一样。Java RMI对于...

    java rmi 参考文档

    ### Java RMI (Remote Method Invocation) 概念与实践 #### 一、Java RMI简介 Java RMI(Remote Method Invocation)是一种允许调用不同Java虚拟机(JVM)上方法的机制。这些JVM可能位于不同的机器上,也可能在同一...

    java RMI简单Demo

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许在不同网络节点上的Java对象之间进行透明的交互。在Java RMI中,一个对象可以调用另一个位于不同JVM(Java虚拟机)...

    JAVA RMI 传输 SSL加密

    Java RMI (Remote Method Invocation) 是一种用于在Java应用程序之间进行远程通信的技术。为了提高RMI通信的安全性,我们可以使用SSL (Secure Sockets Layer) 或其后继者TLS (Transport Layer Security) 进行加密。...

    Java RMI 简单示例

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种用于分布式计算的技术,它允许一个Java对象调用另一个在不同 JVM(Java虚拟机)上的对象的方法。这个简单的示例展示了如何创建一个基本的...

    Java RMI中文规范

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台中用于构建分布式对象系统的关键技术。它允许Java应用程序在不同Java虚拟机(JVM)之间进行远程方法调用,这些虚拟机可能位于同一台计算机或网络上的...

    JavaRMI.pdf

    Java RMI(Remote Method Invocation)是Java编程语言中用于实现远程过程调用的一种技术。它允许运行在客户机上的程序调用位于远程服务器上的对象的方法,从而实现分布式计算。RMI的核心思想是通过接口隐藏底层网络...

    JAVA RMI

    **JAVA RMI(远程方法调用)详解** Java RMI(Remote Method Invocation)是Java平台上的一个核心特性,它允许Java程序在不同的JVM(Java虚拟机)之间进行分布式计算,实现了对象间的远程调用。RMI使得开发者可以像...

    通过Java RMI实现远程调用的一个简单例子

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种用于分布式计算的技术,它允许一个Java对象调用另一个在不同JVM上的对象的方法。这个简单的例子将引导我们了解如何利用Java RMI实现远程...

    java rmi HelloWorld版(源码)

    Java RMI,全称为Remote Method Invocation,是Java平台上的一个标准API,用于实现分布式计算,使得在不同Java虚拟机(JVM)上的对象能够互相调用方法。这个"java rmi HelloWorld版(源码)"的压缩包文件提供了一个...

    JAVA RMI测试代码

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许Java对象在不同的网络环境中进行交互,就像调用本地方法一样。RMI是构建分布式应用的重要工具,尤其适用于需要跨...

    Java RMI 可运行实例

    Java Remote Method Invocation (RMI) 是Java平台提供的一种强大的分布式计算技术,允许在不同网络环境中的Java对象之间进行远程方法调用。这个可运行实例是一个实际应用RMI概念的示例,它展示了如何构建和运行一个...

    javaRMI完整版.pdf

    Java RMI 完整版 Java Remote Method Invocation(RMI)是一种分布式对象技术,允许使用 Java 编写分布式对象,不同的 Java 虚拟机(JVM)之间进行对象间的通讯。这使得应用程序(Application)可以远程调用方法,...

    JAVA RMI简单例子

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许在不同的Java虚拟机之间进行方法调用,仿佛这些方法都在本地对象上执行一样。这个"JAVA RMI简单例子"旨在帮助我们...

Global site tag (gtag.js) - Google Analytics