基于TAPI和PBX實現(xiàn)雙機互連互通
引 言
計算機電話集成是計算機技術和電信技術相結合的產(chǎn)物。電信行業(yè)配備了各種各樣的硬件系統(tǒng),要設計一個考慮兼容所有種類的硬件系統(tǒng)的軟件程序非常困難[1]。為了減輕開發(fā)者的負擔,微軟與Intel 聯(lián)合創(chuàng)建了 Windows Telephony API(TAPI),給應用程序編程者提供一個接口,允許應用程序無需改變就可以適用多種多樣的硬件系統(tǒng)。
1 TAPI通信原理
由于計算機與Modem 之間的通信方式均通過串口進行, 外置Modem 是通過串口線與計算機連接,內(nèi)置Modem 通過虛擬串口實現(xiàn)通信 [2]。計算機與Modem 之間的通信由程序控制串口發(fā)送AT 命令數(shù)據(jù)到Modem。TAPI 扮演了應用程序與串口之間橋梁的角色,保證了軟件開發(fā)的一致性。用戶只需關注基于TAPI 的應用開發(fā),而無需關注不同Modem 所對應的不同AT 命令集。
TAPI 是電話集成的編程工具, 已經(jīng)被集成到 Win32 SDK 中[3],相關的模塊是Tapi32.dll 和Tapisrv.exe。圖 1 示意了 Windows TAPI 的結構。Tapi32.dll 運行于用戶程序進程空間,TAPI 應用程序調(diào)用其中的功能函數(shù) ;Tapi32.dll 與運行于TAPI 服務進程空間的 Tapisrv.exe 通信 [4] ;Tapisrv.exe 與通信硬件TAPI 服務提供者(TAPI Service Provider,TSP)DLL 通信;服務提供者DLL 直接與服務提供者驅動程序通信,并通過驅動程序操作硬件。
在 Windows NT 網(wǎng)絡中, 第一次建立電話環(huán)境時, 應在進程中執(zhí)行 1 個初始化調(diào)用來設置 TAPI 環(huán)境,包括加載Tapi32.dll、執(zhí)行TAPI 服務Tapisrv.exe、加載注冊庫中有關的電話設備驅動程序[5]。
為了開發(fā) TAPI 應用程序,必須調(diào)用Tapi32.dll 所提供的一系列函數(shù)。微軟在 Win32 SDK 中提供了 Tapi32.dll 的頭文件 Tapi.h 和輸入庫文件 Tapi.lib。任何調(diào)用Tapi32.dll 中函數(shù)的工程都必須包含此頭文件和連接該輸入庫[6]。
2 TAPI通信實現(xiàn)
城際交換機連接兩個計算機實現(xiàn)雙機互連通信,如圖 2 所示,因其線路簡單、較容易實現(xiàn),在現(xiàn)實中有許多應用場景。比如通過PC撥打電話,或者通過穩(wěn)定可靠的電話線路收發(fā)送文件等。
在PC上開發(fā)應用程序實現(xiàn)采用電話線路通信,采用基于TAPI 類庫構建用戶類庫的方法實現(xiàn)應用程序開發(fā)。在用戶類庫里實現(xiàn)編制電話數(shù)據(jù)應用程序,流程如圖 3 所示。編制電話數(shù)據(jù)應用程序大致經(jīng)過如下過程:
(1) 初始化 TAPI。通過調(diào)用函數(shù)lineInitializeEx在應用程序中完成 TAPI的初始化。
(2) 協(xié)調(diào) TAPI版本。應用程序使用lineNegotiateAPI Version函數(shù)把 API使用版本通知給TAPI,返回與TAPI通信所能使用的版本。
(3)檢查設備。調(diào)用lineGetDevCaps函數(shù)詢問設備的能力,返回LINEDEVCAPS類型的數(shù)據(jù)結構。設備能力包括TAPI服務提供者、交換機信息、字符串格式、載波方式、數(shù)據(jù)傳輸?shù)取?
(4)打開線路。調(diào)用函數(shù) lineOpen打開 1條線路設備,lineOpen返回線路設備的句柄,用以完成以后對此設備的各種操作??梢栽?1個應用程序中打開多條線路。
(5)初始化線路狀態(tài)。 通過調(diào)用函數(shù) lineSetStatus Messages,初始化線路狀態(tài)設置。
(6)創(chuàng)建偵聽線路信息的線程,同時創(chuàng)建線程事件句柄和線程狀態(tài)句柄。之所以需要線程狀態(tài)句柄,是因為這里所實現(xiàn)的 TAPI通信軟件系統(tǒng)中創(chuàng)建了反饋連接狀態(tài)的線程,需要建立狀態(tài)變化事件句柄通知該線程。
偵聽線程工作時,獲取線程事件,對 TAPI 事件根據(jù)消息 ID 種類分別應對處理。主要包括三種應對方法 :應答、呼叫信息處理、呼叫狀態(tài)處理。呼叫狀態(tài)再根據(jù)消息參數(shù)分別應對處理,處理方法包括:來電響應、空閑、連接、取消連接。線程事件觸發(fā)處理流程如圖 4 所示。
這里基于TAPI 和 PBX 實現(xiàn)的雙機互聯(lián)互通軟件系統(tǒng)運行界面如圖 5 所示。如果安裝了數(shù)據(jù)模式的Modem,打開TAPI 通信后會獲得TAPI 句柄,并據(jù)此可以進行串口通信;如果沒有安裝或安裝了有問題的Modem 會報出無可使用設備的警示。在TAPI 通信沒有打開的情況下,串行通信是不能使用的, 因為沒有獲得通信句柄。
為了測試互連互通功能,將一個 PC 作為被連接對象, 點擊“等候”;將另一個 PC 作為主動連接對象,輸入對端電話號碼,并點擊“撥號”。連接成功后即可互發(fā)數(shù)據(jù)。發(fā)送端輸入一串字符點擊發(fā)送,接收端讀取到的數(shù)據(jù)顯示在接受對話框里,收發(fā)數(shù)據(jù)相同,且反向撥號連接和反向數(shù)據(jù)收發(fā)都是可以的,至此實現(xiàn)了基于TAPI 和PBX 雙機互連互通功能。
結 語
使用微軟 TAPI 類庫,實現(xiàn)了基于PBX 雙機互連互通, 一方面說明基于TAPI 的電話線路通信無需關注底層Modem 板卡,只需關注應用開發(fā) ;另一方面說明了采用微軟這種電話API 通信架構確實有效,給應用開發(fā)帶來了方便。





