JacORB配置步驟

來源:互聯網
上載者:User

JacORB的應用開發一般分為以下五步:
    1.寫IDL介面定義編譯IDL

2.介面定義產生Java類

3.實現步驟2中產生的介面

4.寫伺服器啟動類,並註冊到ORB

5.寫用戶端去擷取服務物件引用 下載安裝Jacorb2.2.4

1)           從http://www.jacorb.org/download.html下載JacORB 2.2.4,解壓縮到磁碟上,例如C:\JacORB

2)           在系統內容變數中設定 

classpath=.;C:\JacORB\lib\idl.jar;

C:\JacORB\lib\jacorb.jar;

C:\JacORB\lib\classes; 

 另外,為了方便使用ant和命令列工具,在path中加入C:\JacORB\bin

3)           接著,把C:\JacORB\etc目錄下的jacorb_properties.template複製到C:\JacORB\classes目錄下,並更名為jacorb.properties

4)           配置命名服務, 編輯jacorb.properties檔案

設定其中的 ORBInitRef.NameService=file:/ D:/JacORB/NS_Ref,這個NS_Ref檔案會在啟動命名服務時產生.該設定檔其餘部分保留預設值即可. 測試命名服務(NS,Naming Service)是否可以正常啟動

1)          在C:\JacORB\bin目錄下找到檔案jac.bat.tpl,更名為jac.bat

2)           在dos視窗下輸入   ns  NS_Ref
    如果出現下面的輸出說明已經正常啟動

[jacorb.orb.print_ver] INFO:

        JacORB V 2.3.0, www.jacorb.org
        <C>  The JacORBproject 17-Feb_2007

 [jacorb.orb] INFO :Property”jacorb.hashtable_class” is set to:java.util.Hashtable

……

……

 [jacorb.naming] INFO : NS up

[jacorb.orb] INFO : ORB run

 如果沒有任何輸出,可能是由於你的jacorb.properties檔案沒有放到classpath所在的目錄下。

 

public static void main( String [] args )
 {
  Hashtable env = new Hashtable();
  env.put(Context.INITIAL_CONTEXT_FACTORY,"org.jnp.interfaces.NamingContextFactory");
  env.put(Context.PROVIDER_URL, "localhost:1099");
  env.put("java.naming.factory.url.pkgs","org.jboss.naming:org.jnp.interfaces");
  try
  {
   Context ctx = new InitialContext(env);
   Object obj = ctx.lookup( "HelloWorld" );
   HelloWorldHome home =(HelloWorldHome)javax.rmi.PortableRemoteObject.narrow(
obj, HelloWorldHome.class );
   HelloWorld helloWorld = home.create();
   System.out.println( helloWorld.hello());
   helloWorld.remove();
  }
  catch ( Exception e )
  {
   e.printStackTrace();
   System.out.println( "Exception: " + e.getMessage() );
  }
 }

 

 

 

要體現CORBA技術的運作,就從這個helloworld級的CORBA開始,用Java寫

1. 介面定義 (Hello.idl)
Hello.idl
module HelloApp
{
interface Hello
{
string sayHello(in string message);
};
};

裝了Java就內建了工具idlj(jdk1.3.0_01以上版本,之前版本的是idltojava或idl2java),為介面定義檔案產生用戶端存根和伺服器架構。具體操作如下:
idlj -oldImplBase -fall Hello.idl

編譯後將在 HelloApp 子目錄中形成以下六個檔案:
●_HelloImplBase.java
該抽象類別是一個伺服器 skeleton,它可為伺服器提供基本的 CORBA 功能。它實現 Hello.java 介面。伺服器類 HelloServant 擴充 _HelloImplBase。
● _HelloStub.java
該類是客戶機 stub,可為客戶機提供 CORBA 功能。它實現 Hello.java 介面。

●Hello.java
該介面含有 IDL 介面的 Java 版本。Hello.java 介面擴充 org.omg.CORBA.Object 並提供標準的 CORBA 對象功能。

●HelloHelper.java
這是一個終態類,可以提供協助工具功能,特別是提供將 CORBA 對象引用轉換為適當類型所需的 narrow() 方法。

●HelloHolder.java
這是一個終態類,其中含有 Hello 類型的公有執行個體成員。它可為“out” 和 “inout” 變數提供操作。CORBA 有這些變數,但不容易映射為 Java 的語義。
●HelloOperations.java
這是一個介面類,其中含有方法 sayHello()。

要完成該應用程式,只需在檔案 HelloServer.java 和 HelloClient.java 中提供伺服器和客戶機的實現即可。


2. 介面實現(HelloImpl.java)
HelloImpl.java是Hello IDL 介面的實現;每個Hello執行個體都由一個HelloImpl執行個體來實現。HelloImpl是_HelloImplBase的子類,_HelloImplBase是由 idlj編譯器從樣本 IDL 中產生的。


import HelloApp.*;
public class HelloImpl extends _HelloImplBase {
/* 建構函式 */
public HelloImpl() {
super();
}
/* 實現介面聲明方法sayHello */
public String sayHello(String message) {
System.out.println("我在CORBA的伺服器端,用戶端正在調用'sayHello'方法。 ");
System.out.println("Hello " + message);
return message;
}
}

3. 伺服器端程式(HelloServer.java)
import org.omg.CosNaming.*;
import org.omg.CORBA.*;
public class HelloServer {
public static void main(String args[]) {
try {
/* 建立和初始化 ORB */
ORB orb = ORB.init(args, null);
System.out.println("開始 ORB Server ...");
/* 建立一個執行個體並將其向 ORB 註冊 */
HelloImpl helloImpl = new HelloImpl();
orb.connect(helloImpl);
System.out.println("將執行個體註冊到ORB ");
/* 擷取根命名內容 */
org.omg.CORBA.Object objRef =orb.resolve_initial_references("NameService");
NamingContext ncRef = NamingContextHelper.narrow(objRef);
/* 綁定命名中的對象引用 */
NameComponent nc = new NameComponent("Hello", "");
NameComponent path[] = { nc };
ncRef.rebind(path, helloImpl);
/* 等待來自客戶機的調用 */
java.lang.Object sync = new java.lang.Object();
synchronized (sync) {
sync.wait();
}
System.out.println("等待CORBA用戶端調用...");
} catch (Exception e) {
System.err.println("錯誤: " + e);
e.printStackTrace(System.out);
}
}
}


4. 用戶端程式(HelloClient.java)
import HelloApp.*;
import org.omg.CosNaming.*;
import org.omg.CORBA.*;
public class HelloClient {
public static void main(String args[]) {
try {
/* 建立和初始化 ORB */
ORB orb = ORB.init(args, null);
/* 擷取根命名內容 */
org.omg.CORBA.Object objRef = orb.resolve_initial_references("NameService");
NamingContext ncRef = NamingContextHelper.narrow(objRef);
/* 解析命名中的對象引用 */
NameComponent nc = new NameComponent("Hello", "");
NameComponent path[] = { nc };
Hello h = HelloHelper.narrow(ncRef.resolve(path));
/* 調用 Hello 伺服器對象並列印結果 */
System.out.println("我在用戶端,開始調用CORBA伺服器端的'sayHello'方法");
System.out.println("歡迎, " + h.sayHello("javamxj blog"));
} catch (Exception e) {
System.out.println("錯誤 : " + e);
e.printStackTrace(System.out);
}
}
}



CORBA Server/Client的編譯與運行

· 把上面4個檔案複製到D:\CorbaSample目錄下,在此目錄下建立Client和Server目錄,假設它們分別為用戶端和服務端。

· 編譯Hello.idl
D:\CorbaSample>idlj -oldImplBase -fall Hello.idl
這會產生一個HelloApp的目錄

· 編譯所有java檔案:
D:\CorbaSample>javac *.java HelloApp/*.java

· 分別在Client和Server目錄下建立HelloApp子目錄,將D:\CorbaSample\HelloApp目錄中的
_HelloStub.class
Hello.class
HelloHelper.class
HelloHolder.class
HelloOperations.class
複製到D:\CorbaSample\Client\HelloApp目錄下,再將D:\CorbaSample目錄中的HelloClient.class複製到D:\CorbaSample\Client目錄下。

將D:\CorbaSample\HelloApp目錄中的
_HelloImplBase.class
Hello.class
HelloOperations.class
複製到D:\CorbaSample\Server\HelloApp目錄下,再將D:\CorbaSample目錄中的HelloServer.class和 HelloImpl.class 複製到D:\CorbaSample\Server目錄中
(注意:當然,你可以不必建立Server和Client目錄及以上複製檔案的操作,可以直接在D:\CorbaSample目錄中進行操作,我這樣做的目的主要是為了區分用戶端和服務端)


· 確保名字伺服器處於運行狀態:
D:\CorbaSample\Server>tnameserv -ORBInitialPort 1050


· 在另一個DOS視窗啟動 Hello 伺服器:
D:\CorbaSample\Server>java HelloServer -ORBInitialPort 1050

· 又再在另一個DOS視窗啟動CORBA用戶端調用CORBA服務:
D:\CorbaSample\Client>java HelloClient -ORBInitialPort 1050
(本地調用,不需要用-ORBInitialHost參數來指定遠端IP地址)

D:\CorbaSample\Server>java HelloClient -ORBInitialHost localhost -ORBInitialPort 1050
(遠程調用CORBA服務,可以將localhost替換成遠端IP地址)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.