精品专区-精品自拍9-精品自拍三级乱伦-精品自拍视频-精品自拍视频曝光-精品自拍小视频

網站建設資訊

NEWS

網站建設資訊

在Java中實現遠程方法調用(轉)

在Java中實現遠程方法調用(轉)[@more@]一、Java中的遠程方法調用

遠程方法調用(Remote Method Invocation, RMI)是Java1.1引入的分布式對象軟件包,它的出現簡化了在多臺機器上的Java應用之間的通信。相比CORBA,RMI功能較弱且只能用于Java系統。

二、實現一個簡單的RMI

要使用RMI,必須構造四個主要的類:遠程對象的本地接口、RMI客戶、遠程對象實現和RMI服務器。RMI服務器生成遠程對象實現的一個實例,并用一個特殊的URL注冊它,RMI客戶在遠程服務器上查找對象,若找到就把它轉換成本地接口類型,然后像一個本地對象一樣使用它。下面是一個簡單的RMI例子,遠程對象只返回一個消息字符串。要使這個例子更有價值,我們需要做的就是完善遠程對象實現類。

1.遠程對象的本地接口類(Rem.java)

該類僅僅是一個接口,而不是實現,RMI客戶機可以直接使用它,RMI服務器必須通過一個遠程對象來實現它,并用某個URL注冊它的一個實例。

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


本地接口(Rem)必須是公共的,否則客戶機在加載一個實現該接口的遠程對象時就會出錯。此外,它還必須從java.rmi.Remote繼承而來,接口中的每一個方法都必須拋出遠程異常java.rmi.RemoteException。

2.RMI客戶類(RemClient.java)

RMI客戶使用Naming.lookup在指定的遠程主機上查找對象,若找到就把它轉換成本地接口Rem類型,然后像一個本地對象一樣使用它。與CORBA不同之處在于RMI客戶必須知道提供遠程服務主機的URL,這個URL可以通過rmi://host/path或rmi://host:port/path來指定,如果省略端口號,就使用1099。Naming.lookup可能產生三個異常:RemoteException、NotBoundException、MalformedURLException,三個尋常都需要捕獲。RemoteException、Naming和NotBoundException在java.rmi.*中定義,MalformedURLException在java.net.*中定義。另外,客戶機將向遠程對象傳遞串行化對象Serializable,所以還應在程序中輸入java.io.*。

import java.rmi.*;
import java.net.*;
import java.io.*;
public class RemClient {
public static void main(String[] args) {
try {
String host = (args.length > 0) ? args[0] : "localhost"; //從命令行讀取遠程主機名
//通過URL在遠程主機上查找對象,并把它轉化為本地接口Rem類型
Rem remObject=(Rem)Naming.lookup("rmi://" + host + "/Rem");
System.out.println(remObject.getMessage()); //調用遠程對象的方法
} catch(RemoteException re) {System.out.println("RemoteException: " + re);
} catch(NotBoundException nbe) {System.out.println("NotBoundException: " + nbe);
} catch(MalformedURLException mfe){System.out.println("MalformedURLException:"+ mfe);
}}}
3.遠程對象實現類(RemImpl.java)
這個類真正實現RMI客戶調用的遠程對象,它必須從UnicastRemoteObject繼承,其構造函數應拋出RemoteException異常。
import java.rmi.*;
import java.rmi.server.UnicastRemoteObject;
public class RemImpl extends UnicastRemoteObject implements Rem {
public RemImpl() throws RemoteException {} //構造函數拋出RemoteException異常
public String getMessage() throws RemoteException {
return("Here is a remote message."); }} //向RMI客戶返回一個消息串 4.RMI服務器類(RemServer.java)該類創建遠程對象實現RemImpl的一個實例,然后用一個特定的URL來注冊它,所謂注冊就是通過Naming.bind或Naming.rebind來將RemImpl實例綁定到URL上。 import java.rmi.*; import java.net.*; public class RemServer { public static void main(String[] args) { try { RemImpl localObject = new RemImpl(); //生成遠程對象實現的一個實例 Naming.rebind("rmi:///Rem", localObject); //將遠程對象實例綁定到rmi:///Rem上 }catch(RemoteException re){System.out.println("RemoteException:"+re); }catch(MalformedURLException mfe) {System.out.println("MalformedURLException: "+mfe); }}}

三、編譯和運行

編譯RMI客戶和服務器,這將自動編譯遠程對象的本地接口和遠程對象實現
javac RemClient.java //自動編譯遠程對象的本地接口Rem.java
javac RemServer.java //自動編譯遠程對象實現RemImpl.java
生成客戶承接模塊和服務器框架
rmic RemImpl
這將構造RemImpl_Stub.class和RemImpl_Skeleton.class。請將Rem.class、RemClient.class和RemImpl_Stub.class拷貝到RMI客戶機,將Rem.class、RemImpl.class 、RemServer.class和RemImpl_Skeleton.class拷貝到RMI服務器。
啟動RMI注冊
rmiregistry
//在服務器上執行。不論有多少個遠程對象,本操作只需做一次
運行java RemServer.class
//啟動RMI服務器(在服務器上執行)
java RemClient.class
//啟動RMI客戶,將輸出“Here is a remote message.”
文章題目:在Java中實現遠程方法調用(轉)
瀏覽路徑:http://m.jcarcd.cn/article/isggoe.html
主站蜘蛛池模板: 午夜免费观看福利片 | 欧美日韩国产中文 | 区二区三区综合片 | 91久精品 | 青青青爽国产 | 国产按摩院在线网站 | 青青草极品视觉盛 | 精品第一页 | 国产香蕉 | 91男女免费福利 | 国产精品露脸国语 | 国产精品尤物在线 | 国产尤物在线观 | 精品在线一区91 | 91福利导航视频 | 午夜国产精品理论 | 91这里有精品 | 国产啪精品视频网站 | 蜜臀视频| 国产视频第一页 | 欧美日韩不卡中文网 | 欧美一区二区 | 99热在线观看精品 | 国产做a∨在线视频 | 亚洲无码日 | 国产日韩情 | 乱伦免费国产高 | 欧美三极婬片网站 | 国产日韩海的味道 | 日产美产国产一区 | 国产精品女同一区二 | 日本免费一区 | 国产91色在 | 午夜人成影视免费 | 国产亚洲a | 91视频一区在线 | 国产精品手机在线 | 日本成人A123区 | 日本精品免费 | 日韩经典欧美国产 | 欧美日韩国产第一页 |