|
分布式開發的歷史
利用Remote方式調用遠程對象實現服務器與客戶端之間通訊是一種常用的網絡開發方式,在.NET與Java開發當中,對Remote遠程對象早已有著足夠的支持(對Remote遠程對象調用有興趣的朋友歡迎參考一下利用遠程對象實現分布式開發)。
從2003年開始.NET當中就盛傳著.NET Remoting遠程對象調用的分布式開發,.NET Remoting主要用于管理跨應用程序域的同步和異步RPC 會話。在默認情況下,Remoting可以使用 HTTP 或 TCP 協議進行信息通訊,并使用 XML 編碼的 SOAP 或二進制消息格式進行數據交換。.NET Remoting 提供了非常靈活和可擴展的編程框架,并且可以管理對象的狀態。在Framewok2.0出臺以后,WCF盛世登場,它是綜合了.NET Remoting遠程對象,TCP/IP套接字,Web服務,MSMQ,P2P點對點等各類型通信方式的產物,WCF使遠程通信進入另一個臺階。
而在Java方面,對遠程通信也有強大的支持,它定義了的RPC(Remote Procedure Call Protocol)協議是—項遠程過程調用協議,它可以通過網絡從遠程計算機請求的服務獲得計算結果,它無需了解底層網絡技術的協議就可以使用如TCP或UDP等通信方式,為程序之間傳遞信息數據。在網絡通信模型中,RPC跨越了傳輸層和應用層。RPC使系統更容易地實現分布式式開發。但RPC通訊卻并未實現面向對象的開發原則,到而RMI(Remote Method Invocation)遠程方法調用是一種計算機之間利用遠程對象互相調用實現通訊的一種機制。它以面向對象的開發方式,利用RPC協議,使服務器與客戶端的對象能夠實現遠程調用。
但在.NET Remoting與RMI通信中同時存在一個弊端,那就是對開發語言的限制,無論是使用哪一種通訊方式,服務器與客戶端都必須支持同一種開發語言。通訊過程中不能跨越開發語言的限制,這是一個人令人懊惱的消息。因為在大型的開發項目當中,往往會集合著不同語言開發進行不同模塊的開發。而使用Remote進行分布式開發,可以提高通信的效率但卻又受到限制。對此,各大開發公司做出了積極的貢獻,開發出如J-Integra(又名Ja.NET),IIOP.NET(InterNET Inter-Orb Protocol),JNBridge等集成開發工具,對.NET與Java之間實現Remote遠程對象的相互調用作出足夠的支持。下面在下為大家對“JNBridge實現.NET與Java的相互操作”作出詳細的介紹。
JNBridge概述
NBridge是一種領先的Java與.NET互操作的的產品,憑借JNBridge技術,Java和.NET代碼無需交叉編譯器就可以實現對象共享。所有Java代碼運行在JVM上,而.NET代碼則運行在CLR上。在該方案下,JVM和CLR可以運行在不同的機器上,也可以運行在一臺機器的不同進程上,甚至還能運行在相同的進程的不同應用程序域上。經歷多年的發展,JNBridge已經發布了JNBridgePro 5.0,JNBridgePro 5.0有著更強大的功能。
- 支持ava和.NET之間的跨平臺事務;
- 支持Microsoft Visual Studio和Eclipse插件;
- 兼容Windows 7;
- 跨平臺交易一體化主要是對用戶透明;
- '回滾'- 任何一方的終止都將導致雙方的行動被回滾;
JNBridge支持.NET To Java ,Java To .NET兩種服務方式,并可以行用TCP、HTTP、SOAP等多個協議進行雙方通訊,下面就以 “Java調用.NET” 實現一個簡單開發例子,介紹一下JNBridge的功能。
JNBridge配置
首先可以在JNBridge的官方網站http://www.jnbridge.com/downloads.htm 下載程序,安裝JNBridgePro 5.0后,啟動JNBProxy v5.1.exe,選擇Create new Java->.NET Project,新建一個項目后,點擊Project->Java Options對系統進行配置。首先設置好本機的Java.exe應用程序和jvm.dll程序集的路徑,然后設置jnbcore.jar和bcel.jar的路徑(在5.1版本中,這兩個文件存在于“/JNBridge/JNBridgePro v5.1/jnbcore/”),最后可以選擇HTTP或TCP通訊方式(在此例子當中在下選擇TCP通訊,系統默認接口為8085你也可以選擇自定義的接口)。點擊“OK”按鈕,配置完成時,系統將自動生成一個 "/JNBridge/JNBridgePro v5.1/jnbcore/jnbcore_tcp.properties" 文件記錄TCP配置信息。
.NET服務端開發
假如閣下使用的是Visual Studio 2008或者Visual Studio 2010版本,系統將會感知JNBridge的存在,在新建項目時,可以直接新建一個DotNETJavaProxies項目。在此在下想展示一下JNBridge的轉換性能,所以直接新一個解決方案。添加一個Model項目,加入Person類,為Person加入Serializable特性,注意要去除不必要的引用,因為對Framework的引用在轉換時將變為對應的包。
using System;
namespace Model
{
[Serializable]
public class Person
{
public int ID
{
get;
set;
}
public string Name
{
get;
set;
}
public int Age
{
set;
get;
}
}
}
NET技術:JAVA與.NET的相互調用——利用JNBridge橋接模式實現遠程通訊,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。