• <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        當(dāng)前位置:雨林木風(fēng)下載站 > 技術(shù)開發(fā)教程 > 詳細(xì)頁面

        5.3  CORBA技術(shù)及案例

        5.3 CORBA技術(shù)及案例

        更新時(shí)間:2022-05-03 文章作者:未知 信息來源:網(wǎng)絡(luò) 閱讀次數(shù):

        5.3CORBA技術(shù)及實(shí)例
        CORBA是一種規(guī)范,它定義了分布式對象如何實(shí)現(xiàn)互操作。在WorldWideWeb盛行之前,特別是Java編程語言風(fēng)靡之前,C++開發(fā)者基本將CORBA作為其高端分布式對象的解決方案。
        實(shí)際的CORBA規(guī)范歸對象管理組(ObjeotManagementGroup)管轄,這是一家由700多家公司組成的開放的研討會(huì),其工作是制訂對象計(jì)算的開放標(biāo)準(zhǔn)。CORBA對象可以用任何一種CORBA軟件開發(fā)商所支持的語言,如C、C++、Java、Ada和Smalltalk,來編寫。同樣地,CORBA對象可以運(yùn)行在任何一種CORBA軟件開發(fā)商所支持的平臺(tái)上,如Solaris,Windows95/NT,OpenVMS、DigitalUnix、HP-UX或AIX等。這意味著,我們可以在Windows95下運(yùn)行Java應(yīng)用程序,同時(shí)動(dòng)態(tài)調(diào)入并使用C++對象,而實(shí)際上,該對象可能存儲(chǔ)于一個(gè)在Internet上的UnixWeb服務(wù)器上。
        使用接口描述語言(InterfaceDescriptionLanguage)編寫的對象接口,使得與語言無關(guān)的獨(dú)立性成為可能。IDL使得所有CORBA對象以一種方式被描述,僅僅需要一個(gè)由本地語言(C/C++、CORBA、Java)到IDL的“橋梁”。CORBA對象的互通信要以對象請求解析器(Object Request Broker)為中介,這種互通可以在多種流行通信協(xié)議之上(如TCP/IP或是IPX/SPX)實(shí)現(xiàn)。在TCP/IP上,來自于不同開發(fā)商的ORB用InternetInter-Orb協(xié)議(IIOP)進(jìn)行通訊,這是CORBA2.0標(biāo)準(zhǔn)(最新的版本)的一部分。
        目前,對于較為流行的編程語言(包括C++,Smalltalk,Java和Ada95),已經(jīng)有了許多第三方的ORB。隨著其他語言的逐漸流行,CORBA開發(fā)商毫無疑問地要做出相應(yīng)的ORB來支持它們。
        5.3.1CORBA簡介
        最初,OMG在1990年制訂了對象管理體系(ObjectManagementArchitecture),即OMA,來描述應(yīng)用程序如何實(shí)現(xiàn)互操作。作為其中的一部分,需要有一個(gè)標(biāo)準(zhǔn)規(guī)范應(yīng)用程序片段即對象的互操作──這導(dǎo)致了CORBA的誕生。OMA定義了組成CORBA的四個(gè)主要部分。(圖1.1)

        圖1.1OMG的CORBA參考模型
        lObject Request Broker,ORB作為對象互通訊的軟總線。
        lObject Services,定義加入ORB的系統(tǒng)級(jí)服務(wù),如安全性、命名和事務(wù)處理。
        lCommon Facilities定義應(yīng)用程序級(jí)服務(wù),如復(fù)合文檔等。
        lApplication Interface 定義現(xiàn)實(shí)世界的對象和應(yīng)用,如飛機(jī)或銀行帳戶。
        1.ObjectRequestBroker詳述
        OMA最重要的部分就是ORB。為了創(chuàng)建一個(gè)遵從CORBA規(guī)范的應(yīng)用程序,ORB是CORBA四大部分中唯一必須提供的。許多ORB版本根本不帶CORBAServices或是CORBAFacilities,你可以自制(或購買)商用對象。但是,沒有ORB,CORBA應(yīng)用程序絕對無法工作。(圖5.2)

        圖5-.2 單個(gè)ORB的體系結(jié)構(gòu)
        CORB ORB最顯見的功能,是對你的應(yīng)用程序或是其它ORB的請求予以響應(yīng)。在CORBA應(yīng)用程序運(yùn)行期間,你的ORB可能被請求做許多不同的事情,包括:
        l查找并調(diào)用遠(yuǎn)程計(jì)算機(jī)上的對象
        l負(fù)責(zé)不同編程語言之間的參數(shù)轉(zhuǎn)換(如C++到Java)
        l可超越本機(jī)界限的安全管理
        l為其它的ORB收集并發(fā)布本地對象的metadata
        l用下載的代碼(stub)中描述的靜態(tài)方法調(diào)用去擊活遠(yuǎn)程對象中的方法
        l用動(dòng)態(tài)方法調(diào)用擊活遠(yuǎn)程對象
        l自動(dòng)擊活一個(gè)當(dāng)前沒有裝入內(nèi)存運(yùn)行的對象。
        l將回調(diào)方法導(dǎo)引向其管理之下的本地對象
        實(shí)現(xiàn)細(xì)節(jié)對軟件開發(fā)者的透明性,是ORB的一個(gè)杰出的特性。用戶只須在代碼中提供相應(yīng)的hooks,用于初始化ORB并向ORB登記該應(yīng)用程序,就可以將該應(yīng)用程序和大量分布式對象建立聯(lián)系。
        2.用IDL描述對象
        為了保持CORBA的商業(yè)中立性和語言中立性,必須有一個(gè)中介,存在于象C++CORBA服務(wù)器代碼和JavaCORBA客戶機(jī)這樣的實(shí)體之間。這就是IDL。一個(gè)底層對象的若干相關(guān)方法和屬性被IDL集入一個(gè)單一接口。一旦IDL接口定義完成,它可以以stub碼或框架代碼(skeletoncode)的形式編譯成你選用的語言。在所有的ORB中都有IDL編譯器。例如,VisigenicVisiBrokerforJavaORB中就含有Java/IDL編譯器,而VisigenicVisiBrokerforC++ORB則提供了C++/IDL編譯器。
        有一點(diǎn)值得注意的是IDL不同于其它的面向?qū)ο蟪绦蛟O(shè)計(jì)語言,我們不能用它指定它所定義的類或是方法的具體實(shí)現(xiàn)。因此,將它僅僅作為一種定義底層對象接口的語言要好得多。
        就象在Java中將屬性和方法封裝到相關(guān)的類中一樣,上述各項(xiàng)均包含在IDL的模塊之中。在一個(gè)模塊之中可以定義一個(gè)或多個(gè)接口。表一中的簡單IDL模塊名為TheModule,它含有一個(gè)稱為TheInterface的基本接口。該接口僅有一個(gè)定義為整型的簡單變量(即TheVariable)。
        5.3.2用Java做CORBA開發(fā)實(shí)例
        為了創(chuàng)建一個(gè)分布式的Java小應(yīng)用,并讓它用CORBA訪問服務(wù)器對象,我們利用一個(gè)流行的商用ORB,并用IDL定義對象接口。在示例小應(yīng)用中,我們選用了Visigenic VisiBroker for Java。這種ORB已經(jīng)經(jīng)過Oracle、Netscape和Novell等公司的認(rèn)證,并已被納入NetscapeNavigator4.0。
        注意:你可以在非NetscapeNavigator4.0的瀏覽器中運(yùn)行這個(gè)小應(yīng)用。由于它首先要從別處下載一些Java類文件,啟動(dòng)速度可能會(huì)稍慢一些。
        我們將用一個(gè)簡單的Java小應(yīng)用調(diào)用一個(gè)使用CORBA的服務(wù)器對象。為簡單起見,同樣用Java書寫服務(wù)器對象。該服務(wù)器對象用一個(gè)數(shù)組存儲(chǔ)有關(guān)各種CORBAORB開發(fā)商及他們產(chǎn)品的信息。客戶小應(yīng)用將調(diào)用該對象并查詢數(shù)組。一個(gè)更為完整的例子(仔細(xì)思考一下)是將ORB信息存儲(chǔ)于關(guān)系數(shù)據(jù)庫中,利用JDBC(或是別的數(shù)據(jù)庫訪問方法)獲得相關(guān)信息。這種方法將用CORBA生成一個(gè)真正的三層應(yīng)用程序。
        1.最簡單的IDL模塊
        Module TheModule
        {
        interface TheInterface
        {
        long TheVariable;
        };
        };
        如果你用一個(gè)IDL到Java的編譯器編譯這個(gè)IDL模塊(如Visigenic的idl2java),就會(huì)得到表1-2中的Java接口。
        表1-2與TheModule相應(yīng)的Java代碼
        package TheModule;
        public interface TheInterface
        {
        public int TheVariable;
        }
        2.ORBQuery小應(yīng)用
        這個(gè)客戶端的小應(yīng)用含有標(biāo)準(zhǔn)的JavaGUI,并將調(diào)用一個(gè)遠(yuǎn)程CORBA對象。一旦該對象被調(diào)用,就可以使用其方法獲得某一指定CORBA ORB的信息。在服務(wù)器端,為了獲得特定ORB的如下信息:名稱(Name)、銷售商(Vendor)、操作系統(tǒng)(OperatingSystem)、語言(Languages)和URL,我們必須定義五個(gè)方法。因此,必須在IDL接口中定義這五種方法才能獲取相應(yīng)信息。表1-3定義了這個(gè)名為ORBInfo的接口:
        表1-3:ORBInfoIDL界面
        module ORBQuery
        {
        interface ORBInfo
        {
        string GetName(in long index);
        string GetVendor(in longindex);
        string GetOS(in long index);
        string GetLanguages(in longindex);
        string GetURL(in longindex);
        };
        };VisiBroker安裝中含有一個(gè)IDL編譯器──idl2java,你可以用它生成實(shí)現(xiàn)該接口必需的Java代碼。軟件安裝完成之后,只要執(zhí)行如下命令即可生成代碼:
        idl2javaORBInfo.idl
        這步操作將創(chuàng)建一個(gè)名為ORBQuery的子目錄(與ORBQueryJava包相對應(yīng))。在該目錄內(nèi)有8個(gè)文件:ORBInfo.java,ORBInfoHolder.java、ORBInfoHelper.java、_st_ORBInfo.java,_sk_ORBInfo.java、ORBInfoOperations.java、_tie_ORBInfo.java和_example_ORBInfo.java。你可能已經(jīng)猜到,ORBInfo.java文件含有定義ORBInfo接口的Java源文件,但其它的Java類又怎樣呢?
        ORBInfoHolder.java文件內(nèi)含有一個(gè)傳遞參數(shù)時(shí)使用的主類(holderclass),而ORBInfo-Helper類則定義了各種實(shí)用函數(shù)。_st_ORBInfo類定義了客戶stub,_sk_ORBInfo定義了服務(wù)器框架類(skeletonclass)。
        ORBInfoOperations和_tie_ORBInfo類用于實(shí)現(xiàn)一種捆綁機(jī)制,這是VisiBroker的一個(gè)特性,它使得實(shí)現(xiàn)類能夠繼承框架類之外的類。在示例中,我們不會(huì)直接使用這幾個(gè)類。最后,_example_ORBInfo含有一個(gè)示例服務(wù)器對象,對它加以擴(kuò)展就可創(chuàng)建一個(gè)服務(wù)器應(yīng)用程序。
        通過IDL編譯器生成的這八個(gè)Java類,我們可以構(gòu)建一個(gè)框架,由一個(gè)接口(interface)、一個(gè)stub、一個(gè)skeleton和幾個(gè)幫助類,我們可以用Java創(chuàng)建自己的客戶機(jī)/服務(wù)器模式的CORBA應(yīng)用程序。
        3.創(chuàng)建服務(wù)器應(yīng)用程序
        下面,我們需要?jiǎng)?chuàng)建一個(gè)向服務(wù)器ORB登記ORBInfo對象的服務(wù)器應(yīng)用程序。這個(gè)新對象將擴(kuò)充框架類(skeletonclass)并實(shí)現(xiàn)ORBInfo接口。因此,該服務(wù)器共需兩個(gè)新類:一個(gè)用于定義服務(wù)器對象并實(shí)現(xiàn)ORBInfo接口,另一個(gè)向服務(wù)器ORB登記該對象。ORBQuery類包含的標(biāo)準(zhǔn)Java代碼負(fù)責(zé)取回?cái)?shù)組中的指定元素。Server類中含有CORBA特有的功能。
        接下來的例子中,開始是初始化ORB。然后,用“ORBInfo”字符串向ORB登記類,客戶機(jī)利用這個(gè)字符串檢索一個(gè)對象。所有的操作完成后,調(diào)用boa.obj_is_ready(),通知ORB一切準(zhǔn)備就緒。
        表1-4是Server類,它向ORB登記了ORBInfo對象。
        表1-4 服務(wù)器類
        public class Server {
        public static void main(String[] args) {
        try {
        // Initialize the ORB.
        org.omg.CORBA.ORB orb = org.omg.CORBA.ORB.init();
        // Initialize the BOA.
        org.omg.CORBA.BOA boa = orb.BOA_init();
        // Create the ORBQuery.
        ORBQuery serverQuery = new ORBQuery("ORBInfo");
        // Export the newly create object.
        boa.obj_is_ready(serverQuery);
        System.out.println(serverQuery + " is ready.");
        // Wait for incoming requests
        boa.impl_is_ready();
        }
        catch(org.omg.CORBA.SystemException e) {
        System.err.println(e);
        }
        }
        }

        表1-5給出了ORBQuery類,它實(shí)現(xiàn)了接口及五個(gè)幫助方法。
        表1-5:ORBQuery類
        import java.util.*;
        class ORBQuery extends ORBQuery._sk_ORBInfo {
        String[][] ORBVendors =
        {{"PowerBroker","Orbix","VisiBroker","ComponentBroker","
        Solaris NEO"},
        {"Expersoft Corp.","Iona Technologies","Visigenic Software",
        "IBM","Sun"},
        {"OLE and ActiveX Bridges; Windows95/NT;
        Solaris; HP-UX; AIX; JDK 1.0.2",
        "Windows95/NT, MVS, OS/2, QNX, VxWorks, Solaris, HP-UX,
        Irix, AIX, Digital UNIX, OLE Bridge",
        "Windows95/NT, Sun OS, Solaris, HP-UX, AIX, Irix",
        "Windows95/NT, Solaris, HP-UX, AIX, OS/390, OS/2, AS/400",
        "Solaris (Client & Server), Windows95/NT (client), JDK 1.0.2"},
        {"C++, Java", "Java, Smalltalk, Ada95, C++", "Java, C++",
        "Java, C++", "Java, C++"},
        {"http://www.expersoft.com", "http://www.iona.com",
        "http://www.visigenic.com",
        "http://www.software.ibm.com/ad/cb", "http://www.sun.com/solaris/neo/solaris_neo/index.html"}};
        ORBQuery(String name) {
        super(name);
        }
        public java.lang.String GetName(int index)
        {
        String Name;
        Name = ORBVendors[index][0];
        return Name;
        }
        public java.lang.String GetVendor(int index)
        {
        String Vendor;
        Vendor = ORBVendors[index][1];
        return Vendor;
        }

        public java.lang.String GetOS(int index)
        {
        String OS;
        OS = ORBVendors[index][2];
        return OS;
        }

        public java.lang.String GetLanguages(int index)
        {
        String Languages;
        Languages = ORBVendors[index][3];
        return Languages;
        }

        public java.lang.String GetURL(int index)
        {
        String URL;
        URL = ORBVendors[index][4];
        return URL;
        }
        }
        至此,我們已經(jīng)寫好了所有服務(wù)器方必需的代碼,下一步的工作是創(chuàng)建客戶小應(yīng)用,初始化客戶ORB,進(jìn)而擊活并調(diào)用剛剛生成的服務(wù)器對象。
        4.創(chuàng)建CORBA小應(yīng)用
        正如服務(wù)器對象要向服務(wù)器ORB登記一樣,客戶端小應(yīng)用或應(yīng)用程序需要向客戶機(jī)ORB登記。當(dāng)要獲得遠(yuǎn)程CORBA對象時(shí),客戶機(jī)采用了一種間接的方法,它通知客戶機(jī)ORB其意圖,由ORB負(fù)責(zé)ORB到ORB的通訊。這種請求方式由下面兩行代碼實(shí)現(xiàn)(在VisiBrokerforJava中):
        //初始化ORB(使用applet)
        org.omg.CORBA.ORBorb=org.omg.CORBA.ORB.init(this);
        //檢索applet要調(diào)用的ORBInfo接口對象
        ORBInfoQuery=ORBQuery.ORBInfoHelper.bind(orb,"ORBInfo");
        執(zhí)行了bind()方法調(diào)用之后,我們的ORBInfoQuery本地變量與服務(wù)器的ORBInfo對象綁在一起。這一操作完成之后,我們就可以調(diào)用幫助方法來實(shí)現(xiàn)客戶端小應(yīng)用。記住,盡管示例中我們完全使用了Java語言,但實(shí)際上,服務(wù)器對象也可以用其他語言來實(shí)現(xiàn),如:COBOL、C++、Ada和Smalltalk。
        5.編寫簡單的CORBA服務(wù)的一般流程 
        (以Java2為例):
        l編寫所需要的接口IDL文件。
        nfoo.idl
        module foo{
        interface function{
        float square_root(in float number);
        }
        }
        l用idltojava編譯idl文件。
        nidltojava –fno-cpp foo.idl
        l用Javac編譯所產(chǎn)生的類。
        njavac ~\*.java
        l生成實(shí)現(xiàn)類。
        n(functions.java) functinosImpl.java
        l生成實(shí)現(xiàn)服務(wù)器。
        nfooServer.java
        l生成客戶機(jī)應(yīng)用程序(或小程序)。
        nfooClient.java
        l編譯實(shí)現(xiàn)服務(wù)器和客戶機(jī)代碼。
        njavac functionsImpl.java fooServer.java fooClient.java
        l啟動(dòng)命名服務(wù)應(yīng)用程序tnameserv。
        ntnameserv –ORBInitialPort 1080
        l啟動(dòng)服務(wù)器(用命名服務(wù)注冊)。
        njava fooServer –ORBInitialPort 1080
        l啟動(dòng)客戶機(jī)。
        njava fooClient –ORBInitialPort 1080
        6.結(jié)論
        與單純的Java小應(yīng)用相比,創(chuàng)建CORBAJava應(yīng)用稍顯復(fù)雜。事實(shí)上,這同樣比用RMI創(chuàng)建純粹的Java分布式對象應(yīng)用要難一些。但是,CORBA和Java的聯(lián)合,所創(chuàng)建的應(yīng)用程序功能更為強(qiáng)大,更具可擴(kuò)充性,這是單純用JDK開發(fā)所無法比擬的。另外,現(xiàn)實(shí)是企業(yè)界很少使用Java應(yīng)用程序。CORBA是兩全其美的選擇,一方面它允許開發(fā)者利用已有的代碼保護(hù)投資,另一方面又可以充分發(fā)揮Java編程語言的優(yōu)勢。
        5.4JSP與CORBA技術(shù)的結(jié)合使用
        若想實(shí)現(xiàn)Web上分布式客戶機(jī)/服務(wù)器模式的應(yīng)用程序,可以選擇多種不同的技術(shù)。但是,對于必須服務(wù)于大量用戶的應(yīng)用,我們認(rèn)為應(yīng)該首選CORBA,因?yàn)樗哂锌蓴U(kuò)展性和業(yè)界廣泛的支持。由于CORBA的強(qiáng)健性可以提高Java編程語言的性能,利用已有的基于標(biāo)準(zhǔn)的技術(shù),Java開發(fā)者可以編寫出功能強(qiáng)大的Web應(yīng)用程序。
        想要對已有的Web軟件資源加以利用,或是編寫真正功能強(qiáng)大的應(yīng)用程序,使Internet/Intranet成為通信主干,所使用的技術(shù)必須具有以下特性:
        ·支持現(xiàn)有的C、C++和COBOL代碼
        ·支持Java,以建立具有可移值性、平臺(tái)獨(dú)立性的面向?qū)ο蟮膽?yīng)用程序
        ·商業(yè)中立性,只有這樣,應(yīng)用程序才易于維護(hù),且不會(huì)被時(shí)間淘汰。
        ·可擴(kuò)充性,能夠支持大量用戶
        ·它應(yīng)該被多種平臺(tái)所支持,而不是固定于某種平臺(tái)之上。
        ·開發(fā)模型應(yīng)該是面向?qū)ο蟮模ㄒ驗(yàn)镺OP有許多固有優(yōu)勢)
        ·端到端的安全性
        ·廣泛的業(yè)界支持
        這種技術(shù)便是以CORBA為最佳。
        Servlets是JAVA 2.0中新增的一個(gè)全新功能,它是運(yùn)行在請求/面向請求服務(wù)器上的模塊,比如一個(gè)Java-enabled web 服務(wù)器, 和類似這樣的延伸場合. 例如, 一個(gè)servlet可以從一個(gè)HTML訂單表中獲取數(shù)據(jù)然后用一些商業(yè)上的算法來更新公司相應(yīng)的訂單數(shù)據(jù)庫。
        也就是說:servlet能夠象CGI腳本一樣擴(kuò)展WEB服務(wù)器功能,但是servlet占用很少密集資源,有很多用CGI腳本編制的一些站點(diǎn)由于訪問量劇增,性能迅速下降,這是CGI腳本一個(gè)缺點(diǎn)。同時(shí)由于servlet是用java編寫的,因此是跨平臺(tái)的。可以這樣說,實(shí)際servlet是電子商務(wù)真正的開始。
        跨平臺(tái)的Java Servlet與跨語言的corba的強(qiáng)強(qiáng)聯(lián)合,使得開發(fā)者可以編寫出功能強(qiáng)大的Web應(yīng)用程序。

        溫馨提示:喜歡本站的話,請收藏一下本站!

        本類教程下載

        系統(tǒng)下載排行

        主站蜘蛛池模板: 免费无码又爽又刺激高潮| 精品一区二区三区无码免费视频| 亚洲永久网址在线观看| 亚洲精品乱码久久久久久V| 边摸边吃奶边做爽免费视频网站| a一级毛片免费高清在线| 四虎成年永久免费网站| 五月天婷亚洲天综合网精品偷| 亚洲精品成人无限看| 亚洲国产精品成人综合久久久 | 国产精品黄页在线播放免费| 久久久久亚洲精品天堂久久久久久| 久久亚洲AV成人无码国产| 天天综合亚洲色在线精品| 久久久免费精品re6| 午夜亚洲福利在线老司机| 一级毛片免费毛片毛片| 国产精品视频免费| 亚洲国产精品高清久久久| 激情小说亚洲图片| 国产亚洲大尺度无码无码专线| 亚洲国产成人精品无码区二本| 国产91在线免费| 亚洲爆乳AAA无码专区| 亚洲国产精品尤物yw在线| 精品亚洲av无码一区二区柚蜜| 亚洲国产精品不卡毛片a在线| 中文字幕av免费专区| 四虎永久免费影院在线| 国产成人AV免费观看| 国产偷国产偷亚洲高清日韩| 美女被cao网站免费看在线看| 国产亚洲精aa成人网站| 中文字幕免费在线| 色欲aⅴ亚洲情无码AV| 亚洲av无码不卡| 国产在线观看免费av站| 亚洲国产成人久久三区| 国产高清不卡免费在线| 日本高清免费中文在线看| 亚洲高清无码专区视频|