1、概述
隨著Internet/Intranet的普及以及WEB技術(shù)的發(fā)展,人們對信息的需求越來越強烈,數(shù)據(jù)庫與Internet/Intranet應(yīng)用軟件的集成已經(jīng)成為了非常迫切的問題?;ヂ?lián)網(wǎng)上數(shù)據(jù)庫產(chǎn)品的復(fù)雜,有限的帶寬,以及互聯(lián)網(wǎng)上軟件產(chǎn)品的跨平臺性,將是我們遇到的最大困難。本文通過作者的工作實踐,介紹了JDBC規(guī)范及應(yīng)用JAVA的SOCKET機制,以及JAVA的客戶/服務(wù)器計算模式,最后根據(jù)以上的原理,實現(xiàn)了一個簡單的基于客戶/服務(wù)器的JAVA查詢遠端服務(wù)器上的數(shù)據(jù)庫的小例子。
2、問題提出
當(dāng)我從事Internet/Intranet軟件開發(fā)時,為了達到很好的兼容性,安全性以及跨平臺性,不得不采用JAVA編程,但是JAVA數(shù)據(jù)庫方面的不足,確實眾所周知。雖然JDBC技術(shù)在一段時間以前就已經(jīng)發(fā)布了,但是對于大多數(shù)數(shù)據(jù)庫產(chǎn)品而言,卻要為其編制特殊的驅(qū)動。雖然有一些數(shù)據(jù)庫廠商用JAVA編寫了自己產(chǎn)品的驅(qū)動(如IBM的DB2數(shù)據(jù)庫軟件),但是這類產(chǎn)品的價ge和復(fù)雜的使用方法卻是使一些中小企業(yè)和Internet愛好者們望而卻步,另外,在有限的帶寬下如何減少數(shù)據(jù)的流量等一系列問題,將是解決這類問題的最大的絆腳石。因此,我們必須解決這類問題,并且產(chǎn)生一個跨平臺性的,能掛接多種數(shù)據(jù)庫的,基于客戶/服務(wù)器的軟件解決方案。
3、分析問題
以上的問題我們可以用JAVA的Socket機制實現(xiàn)客戶/服務(wù)器,然后在服務(wù)器端用JDBC來完成客戶端所提交的查詢要求,因此,將問題分為如下兩個方面。
(1)JAVA中的Socket機制
在各種網(wǎng)絡(luò)的客戶/服務(wù)器應(yīng)用中,客戶與服務(wù)器之間的通訊機制是多種多樣的,但大多數(shù)都采用的是基于TCP/IP的Socket機制來完成的,Socket是兩個程序間用來進行雙向傳輸?shù)木W(wǎng)絡(luò)通訊端點,在服務(wù)器程序方面通過IP在網(wǎng)絡(luò)中標(biāo)識自己,然后,通過一個客戶端程序知道的端口號來提供服務(wù),而客戶端在網(wǎng)絡(luò)中通過服務(wù)器的IP來找到服務(wù)器,通過連接他的端口號來獲得服務(wù)器的某項服務(wù)。當(dāng)然,計算機也擁有一些內(nèi)置的用來提供其他服務(wù)的端口和空閑的端口,這樣這些空閑端口就可供程序員來使用。由于Socket通訊機制是一種較為底層的通訊機制,所以通過Socket的數(shù)據(jù)表示是一種原始的字節(jié)流信息。那么客戶端 服務(wù)器的程序就應(yīng)該按照程序員制定的一種約定來進行數(shù)據(jù)的格式化處理后才能進行具體的應(yīng)用,這種約定實際上就是一種協(xié)議。
Socket通訊機制提供了兩種通訊方式,一種是有連接的,另一種是無連接的。有連接的方式是指程序在開始時,雙方就建立了連接,形成了一條通訊鏈路,這條通訊鏈路一直存在,直到任意一方終止連接為止。在連接的同時,雙方就通過這個通訊鏈路進行I/O操作,這種方式是可靠的而且是全雙工的。無連接的方式是指提供不可靠的連接,數(shù)據(jù)傳送時是以數(shù)據(jù)報的方式發(fā)送,類似與我們的寄信。本文采用的為有連接方式。
JAVA在現(xiàn)實中有兩個類用于Socket連接,一個是ServerSocket類,應(yīng)用于服務(wù)器方;一個是Socket,應(yīng)用于客戶方。在服務(wù)器端用如下語句對端口進行初始化及監(jiān)聽:
try{
ServerSocket server=new ServerSocket(9001);//監(jiān)聽9001端口,此端口不能與系統(tǒng)的
//端口號沖突
Socket socket=server.accept();//阻塞進程,一旦有客戶連接初始化socket類
DataInputStream in=new DataInputStream(socket.getInputStream()); //建立輸入流
PrintStream out=new PrintStream(socket.getOutputStream()); //建立輸出流
}
catch(IOException e){}
在客戶端用如下語句即可與服務(wù)器連接:
try{
socket=new Socket(hostname,9001);//連接以hostname的服務(wù)器,端口號為9001
//這里的hostname為服務(wù)器的IP地址
in=new DataInputStream(socket.getInputStream());//初始化輸入流
out=new PrintStream(socket.getOutputStream());//定義輸出流
}catch(IOException e){}
通過以上語句后,在客戶與服務(wù)器之間就建立了in和out這兩個輸入和輸出流,那么就可以進行通信了。最后,為了在服務(wù)器端能響應(yīng)多個客戶端的請求,在服務(wù)器的輸入和輸出流的處理中應(yīng)用了多線程,是每一個線程對應(yīng)一個客戶端的服務(wù),由于JAVA的內(nèi)存管理是一種????管理,當(dāng)某一個客戶的連接斷開后,服務(wù)器程序分配給這一個客戶的線程的資源就會被自動收回。其多線程的語句如下:
new ServerThread(clientname,clientcount,socket).start();
//初始化一個新的ServerThread類(注:ServerThread類為程序的一個線程類
在以上的語句中clientcount為傳給ServerThread類的線程號。
經(jīng)過以上的語句后,客戶端與服務(wù)器端之間就建立了聯(lián)系,而且實現(xiàn)了多線程。
(2)JDBC淺析。
隨著JAVA的興起,JAVA的子公司JAVASOFT為了實現(xiàn)JAVA存取數(shù)據(jù)庫而提供了一套數(shù)據(jù)庫連接規(guī)范JDBC(JAVA DATABASE CONNECTIVITY)有一些數(shù)據(jù)庫廠商根據(jù)這個數(shù)據(jù)庫規(guī)范開發(fā)了自己的數(shù)據(jù)庫JAVA的API,但這些在價ge和使用的復(fù)雜度方面往往讓人難以接受。另外,由于這些API增加了很多功能,是基于瀏覽器的JAVA APPLET加載的速度變慢而且影響了速度。而本程序是為一定需要而設(shè)計的故代碼很小,執(zhí)行速度相對加快。
JAVA為了實現(xiàn)數(shù)據(jù)庫的連接而推出了JDBC規(guī)范,JDBC設(shè)計是基于X/OPEN SQL CLI(CALL LEVEL INTERFACE)這一模型,定義了一組API對象和方法,程序員可以使用這些API與數(shù)據(jù)庫程序進行交互。JDBC API是一個應(yīng)用于數(shù)據(jù)庫的接口,用來解釋和執(zhí)行來自應(yīng)用程序中的SQL語句,并返回結(jié)果集。它可以全部用JAVA寫作為APPLET的一部份下載,又可以是一種本地模塊與現(xiàn)有的數(shù)據(jù)庫連接。如SUN和INTERSOLV合作開發(fā)的JDBC-ODBCBRIDGE就是一種通過JDBC來訪問機器上的已定義的ODBC數(shù)據(jù)源,JDBC-ODBCBRIDEG可以通過在JDBC和ODBC之間建立一個橋梁,讓JAVA程序通過JDBC來訪問ODBC中的數(shù)據(jù)源。
在JDK1.1.5以上的版本中已經(jīng)包含了JDBC-ODBCBRIDGE,讀者如沒有也可從SUN的網(wǎng)站上下載。在我們的程序中即是采用了這一種方式來實現(xiàn)對各種ODBC數(shù)據(jù)源的訪問的。下面我們簡要的介紹一些本套程序要用到的一些基本的類,讀者如想獲得更多的幫助可以察看SUN JDBC的幫助文檔。
DriverManager類用于處理驅(qū)動程序的裝入。使用該類來定義一些程序中使用的所要連接的驅(qū)動,在本程序中就是JDBC-ODBCGRIDGE;
Connection類定義了一個到特定數(shù)據(jù)庫的連接。當(dāng)程序定義了驅(qū)動以后,就要與數(shù)據(jù)庫建立連接,該類將完成這些工作;
Statement類提供了一個執(zhí)行SQL語句的容器。用來提交一個SQL查詢;
ResultSet類用于控制結(jié)果類的存取。其作用是獲得查詢結(jié)果的一些信息,如結(jié)果的紀(jì)錄數(shù),字段數(shù),字段名,結(jié)果集等與結(jié)果相關(guān)的信息。
(注意!由于本程序意在介紹編程方法和思想,所以JDBC的一些具體類的使用方法不屬于本文的范疇。有關(guān)其中具體的使用方法將會在后面程序中寫出。)
新聞熱點
疑難解答