RMI 远程访问

RMI远程访问

看Head First 设计模式时讲到RMI,感觉书上整个流程不是很好懂。自己整理下代码。

代码结构:

RMI
|MyRemote.java
|server
        | MyRemoteImpl.java
|client
        | MyRemoteClient.java

公共接口

感觉stub 和 skeleton就是服务器和客户机的公共访问

import java.rmi.*;
public interface MyRemote extends Remote{
    public String sayHello() throws RemoteException;
}

编译生成的class文件要分别拷贝到 server, client 文件, 服务器类和客户机类javac 要依赖该class文件。

服务器

import java.rmi.*;
import java.rmi.server.*;

public class MyRemoteImpl extends UnicastRemoteObject implements MyRemote{

    public String sayHello(){
        return "Server says, 'Hey'";
    }

    public MyRemoteImpl() throws RemoteException{}

    public static void main(String []args){
        try{
            MyRemote service = new MyRemoteImpl();
            Naming.rebind("RemoteHello", service);
        }catch(Exception ex){
            ex.printStackTrace();            
        }
    }
}

* 服务器运行前要先执行rmiregistry*

客户端

import java.rmi.*;

public class MyRemoteClient{
    public static void main(String []args){
        new MyRemoteClient().go();
    }

    public void go(){
        try{
            MyRemote service = (MyRemote)Naming.lookup("rmi://127.0.0.1/RemoteHello");
            String s = service.sayHello();
            System.out.println(s);
        }catch(Exception ex){
            ex.printStackTrace();

        }
    }
}

运行结果

这里写图片描述

  1. 未启动服务器会有异
  2. 注册
  3. 服务器
  4. 客户端
Java RMI(Remote Method Invocation)允许开发者在Java应用程序之间创建可跨越网络的远程对象,以实现分布式计算。以下是一个简单的步骤概述: 1. **定义接口**[^2]: 开发者首先定义一个接口(`MyRemoteInterface.java`),这个接口将在远程端实现并暴露给客户端。 ```java public interface MyRemoteInterface { String echo(String message); } ``` 2. **实现接口**: 在服务器端,实现这个接口并注册到RMI registry(默认端口1099): ```java Server server = UnicastRemoteObject.exportObject(new MyServiceImpl(), 0); // 注册服务 Naming.bind("rmi://localhost/myService", server); // 在registry中绑定服务名 ``` 这里,`MyServiceImpl`是接口`MyRemoteInterface`的实际实现。 3. **启动服务器**[^1]: 启动RMI服务器,通常会监听指定端口并等待客户端连接。 4. **客户端调用**: 客户端通过`Naming.lookup()`找到服务器地址,并使用反射调用远程方法: ```java try (Registry registry = LocateRegistry.getRegistry("localhost", 1099); MyRemoteInterface service = (MyRemoteInterface) Naming.lookup("rmi://localhost/myService")) { String response = service.echo("Hello from client"); System.out.println(response); } ``` 客户端向服务器发送请求(如echo "Hello"),服务器接收到请求后返回响应。 注意,为了安全起见,在实际生产环境中,应该限制RMI服务器的访问,仅允许来自信任源的客户端连接,并使用安全措施保护序列化数据,防止远程代码执行漏洞(CVE-2018-11774)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值