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

        當前位置:雨林木風下載站 > 技術開發教程 > 詳細頁面

        如何Delphi中操縱撥號網絡

        如何Delphi中操縱撥號網絡

        更新時間:2019-07-04 文章作者:未知 信息來源:網絡 閱讀次數:

        用MODEM撥號上網,仍是大多數個人網民選擇上網的方式.如果能在我們的應用程序中管理撥號 網絡(如Foxmail、Sygate中的撥號功能),無疑將會方便我們的軟件用戶(不用再切換應用程序, 運行撥號網絡),提高我們的軟件的友好性從而提高軟件的競爭力.


        在WIN9X下,如果安裝了撥號網絡,則在WINDOWS系統的系統目錄System下將有兩個撥號網絡管理 程序庫RasApi32.DLL和RasApi16.DLL,我們可利用其中的函數來獲取和設置撥號連接網絡的信息。在 Delphi幫助文件中,有相關函數的說明。


        在此,我們要討論的管理項目有:

        1、獲取當前系統中可用的撥號連接名稱

        2、新建撥號連接、修改撥號連接的屬性

        3、獲取和設置撥號連接的撥號參數

        4、用指定的撥號連接撥號、掛斷指定的撥號連接

        5、獲取當前活動的連接及其連接狀態零、獲取RasAPI函數執行失敗的錯誤信息


        RasAPI的調用接口是統一的,但對于不同的Windows版本,許多常量和數據結構的定義是不同的。 如果使用的數據結構與Windows版本不對應,RasAPI函數執行會失敗;另外,其它原因如其它程序也 在使用同一個撥號連接進行撥號等,也會造成RasAPI函數執行失敗.鑒于此原因,我們需要先討論獲 取RasAPI函數執行失敗的錯誤信息的函數。

        當一個RasAPI函數執行結束時,會返回一個結果標識,為0時表示執行成功,否則作為一個錯誤標 識符表示執行失敗的原因。RasAPI函數RasGetErrorString可以根據錯誤標識符返回其錯誤描述信息,

        在中文WIN9X下可提供一個中文錯誤信息.

        RasGetErrorString的函數原型為:

        function RasGetErrorString (

        uErrorValue : UINT;//錯誤標識符

        lpszErrorString : PChar;//錯誤提示信息的緩沖區

        cBufSize : DWORD//錯誤提示信息的緩沖區大小

        ) : DWORD; stdcall;

        function RasGetErrorString;external RasApiDll name 'RasGetErrorStringA';

        ( 注:RasApiDll = 'Rasapi32.dll'; )


        為了方便,我們可以自己編寫一個函數,用于獲取RasAPI函數執行失敗的錯誤信息。在下面的例

        子中,會經常用到該函數。函數代碼如下所示:

        { 根據錯誤標識符,獲取RasAPI函數執行失敗的錯誤信息 }

        function GetRasError( ErrorID : UINT ) : string;

        var

        buffer : array[ 0..255 ] of char;

        begin

        if 0 = RasGetErrorString( ErrorID

        buffer

        256 ) then

        result := strpas( buffer )//如果能正確返回錯誤信息,則轉化為Pascal字符串

        else//否則返回16進制形式的錯誤代碼

        result := 'GetRasError Failure:ErrorID=' + Format( '%x'

        [ErrorID] );

        end;


        一、獲取當前系統中可用的撥號連接名稱

        即獲取系統中已建立的撥號連接的名稱,可用來讓用戶選擇使用哪個撥號連接進行撥號.

        可以用兩種方法來實現.一種是利用RasAPI函數;另一種是不用RasAPI函數,直接在注冊表中查詢.


        1、不用RasAPI函數,直接在注冊表中查詢

        在注冊表的HKEY_USERS\.Default\RemoteAccess\Addresses下,列出了已經在撥號網絡中建立的撥號連接的名稱及其屬性設置,其中各項目的名稱即為可用的撥號連接的名稱;各項目的值即為各撥號連接的屬性設置,不過是二進制串,筆者還看不懂.由此可見,我們只要讀出各項目的名稱即可獲取當前系統中可用的撥號連接名稱.

        var

        registryTemp : TRegistry;

        stringsTemp : TStringlist;

        begin

        registryTemp := TRegistry.Create;

        stringsTemp := TStringlist.Create;

        with registryTemp do

        begin

        RootKey := HKEY_USERS;//根鍵設置為HKEY_USERS

        //如果存在子鍵.Default\RemoteAccess\Addresses

        if OpenKey('.Default\RemoteAccess\Addresses'

        false) then

        GetValueNames( stringsTemp );//讀出各項目的名稱,即撥號連接名稱

        end;

        combobox1.Items.assign( stringsTemp );//顯示,供選擇

        end;


        2、用RasAPI函數

        RasAPI函數RasEnumEntries可獲取當前系統中可用的撥號連接名稱.其函數原型為

        function RasEnumEntries(reserved : PChar;//保留字段

        必須為NIL

        lpszPhonebook : PChar;//電話本名稱

        在Win9X下無作用

        可為空字符串

        lprasentryname : LPRASENTRYNAME;//接收撥號連接名稱的緩沖區

        是一個RASENTRYNAME類型數組的指針

        var lpcb : DWORD;//接收撥號連接名稱的緩沖區的大小(Bytes)

        var lpcEntries: DWORD//實際獲得的撥號連接名稱的數目

        ) : DWORD; stdcall;

        function RasEnumEntries;external RasApiDll name 'RasEnumEntriesA';


        參數lprasentryname提供了一個RASENTRYNAME類型數組的指針,指向一個接收撥號連接名稱的緩沖區,其中RASENTRYNAME及LPRASENTRYNAME的類型說明如下:


        LPRASENTRYNAME = ^RASENTRYNAME;

        RASENTRYNAME = record

        dwSize : DWORD;//該結構所占內存的大小(Bytes)

        一般設置為SizeOf(RASENTRYNAME)

        szEntryName : array [ 0..RAS_MaxEntryName ] of char;//撥號連接名稱

        end;

        lpcb為緩沖區的大小,一般設置為dwSize的倍數,倍數為可能有的連接的個數.

        lpcEntries實際的連接的個數.


        下面是一個應用例子,列出了當前系統中可用的撥號連接名稱.

        注意,應在RASENTRYNAME緩沖區的第一個RASENTRYNAME結構中設置dwSize.

        const MaxPhoneEntries = 10;//最多的撥號連接數目

        var intIndex : integer;

        PhoneEntries : array[ 0..MaxPhoneEntries - 1 ] of RASEntryName;

        dwSize

        dwEntries

        dwResult : DWORD;

        begin

        //在RASENTRYNAME緩沖區的第一個RASENTRYNAME結構中設置dwSize

        PhoneEntries[ 0 ].dwSize := sizeof( RASEntryName );


        dwSize := MaxPhoneEntries * sizeof( RASEntryName );//為緩沖區的大小

        //調用RasAPI函數,獲取當前系統中可用的撥號連接名稱

        dwResult := RasEnumEntries ( NIL

        ''

        @PhoneEntries[ 0 ]

        dwSize

        dwEntries );


        if dwResult <> 0 then

        begin//RasAPI函數,執行錯誤

        memo1.lines.add('RasEnumEntries錯誤:' + GetRasError( dwResult ));

        exit;

        end;


        //顯示當前系統中可用的撥號連接名稱

        memo1.lines.add('共有' + inttostr( dwEntries ) + '個RAS連接,如下所示');

        for intIndex := 0 to dwEntries -1 do

        memo1.lines.add( strpas( PhoneEntries[ intIndex ].szEntryName ) );

        end;


        3、獲取默認的撥號連接的名稱

        默認的撥號連接,即用戶在瀏覽器中設置的撥號連接,該連接可以認為是用戶最常用撥號連接.

        在注冊表的HKEY_USERS\.Default\RemoteAccess位置,有一個字符串名Profile,它對應字符值即為HKEY_USERS\.Default\RemoteAccess\Addresses.


        二、新建撥號連接、修改撥號連接的屬性

        RasAPI函數RasCreatePhonebookEntry、RasEditPhonebookEntry通過調用Win9X的

        新建撥號連接、修改撥號連接的設置界面,允許用戶新建撥號連接、修改撥號連接,具體的設置操作還要由系統來完成.

        1、新建撥號連接

        新建撥號連接的RasAPI函數為RasCreatePhonebookEntry,其函數原型為:

        function RasCreatePhonebookEntry(

        hwnd : THandle; //新建撥號連接窗口的父窗口的句柄,為NIL表示桌面(DeskTop)

        lpszPhonebook: pchar//電話本名稱

        在Win9X下無作用

        可為空字符串

        ) : DWORD;stdcall;

        function RasCreatePhonebookEntry;external RasApiDll name 'RasCreatePhonebookEntryA';


        函數返回值為0表示執行成功;否則為錯誤代碼.


        下面是一個應用例子,允許用戶新建一個撥號連接.

        var

        dwResult : DWORD;

        begin

        //在當前窗口中新建撥號連接

        dwResult := RasCreatePhonebookEntry( handle

        '' );

        if dwResult = 0 then

        memo1.lines.add('新建撥號連接成功!')

        else

        memo1.lines.add('新建撥號連接失敗:!' + GetRasError( dwResult ))

        end;


        2、修改撥號連接的屬性

        修改撥號連接的屬性的RasAPI函數為RasEditPhonebookEntry,其函數原型為:

        function RasEditPhonebookEntry(

        hwnd : THandle; //新建撥號連接窗口的父窗口的句柄,為NIL表示桌面(DeskTop)

        lpszPhonebook: pchar;//電話本名稱,在Win9X下無作用

        可為空字符串

        lpszEntryName: pchar//撥號連接的名稱,如'163'、'169'等

        ) : DWORD; stdcall;

        function RasEditPhonebookEntry;external RasApiDll name 'RasEditPhonebookEntryA';


        函數返回值為0表示執行成功;否則為錯誤代碼.

        下面是一個應用例子,允許用戶修改指定撥號連接的屬性.

        var

        dwResult : DWORD;

        begin

        //在當前窗口中修改撥號連接的屬性

        dwResult := RasEditPhonebookEntry( handle

        ''

        '163' );

        if dwResult = 0 then

        memo1.lines.add('修改撥號連接成功!')

        else

        memo1.lines.add('修改撥號連接失敗:!' + GetRasError( dwResult ))

        end;


        三、獲取和設置撥號連接的撥號參數

        用RasAPI函數RasGetEntryDialParams、RasSetEntryDialParams可以直接獲取和設置指定撥號連接的撥號參數,其中包括用戶名稱和用戶密碼!

        1、獲取撥號連接的撥號參數

        獲取撥號連接的撥號參數RasAPI函數為RasGetEntryDialParams,其函數原型為:

        function RasGetEntryDialParams(

        lpszPhonebook: pchar;//電話本名稱,在Win9X下無作用

        可為空字符串

        pRASDIALPARAMS:LPRASDIALPARAMS;//撥號參數,是一個RASDIALPARAMS類型的指針

        var lpfPassword : WordBool//是否需要用戶密碼

        ) : DWORD; stdcall;

        function RasGetEntryDialParams;external RasApiDll name 'RasGetEntryDialParamsA';


        參數pRASDIALPARAMS是一個RASDIALPARAMS類型的指針,指向一個撥號連接的撥號參數數據 的緩沖區,其中RASDIALPARAMS及LPRASDIALPARAMS的類型說明如下:

        LPRASDIALPARAMS = ^RASDIALPARAMS;

        RASDIALPARAMS = record

        dwSize : DWORD;//該結構所占內存的大小(Bytes)

        一般設置為SizeOf(RASDIALPARAMS)

        szEntryName : array[0..RAS_MaxEntryName] of char;//撥號連接名稱

        szPhoneNumber : array[0..RAS_MaxPhoneNumber] of char;//撥號號碼

        szCallbackNumber : array[0..RAS_MaxCallbackNumber] of char;//回叫號碼

        szUserName : array[0..UNLEN] of char;//用戶名稱

        szPassword : array[0..PWLEN] of char;//用戶密碼

        szDomain : array[0..DNLEN] of char;//域名

        end;

        函數返回值為0表示執行成功;否則為錯誤代碼.

        下面是一個應用例子,獲取指定撥號連接的撥號參數.

        var

        dwResult : DWORD;

        RASDIALPARAMSData : RASDIALPARAMS;

        NeedPWD : WordBool;

        begin

        //指定撥號連接的名稱

        with RASDIALPARAMSData do

        begin

        dwSize := sizeof( RASDIALPARAMS );//結構大小

        szEntryName := '163';//指定撥號連接的名稱

        szUserName := '';//其它五個參數初始化

        szPassword := '';

        szDomain := '';

        szCallbackNumber := '';

        szPhoneNumber := '';

        end;

        NeedPWD := true;//需要用戶密碼


        //獲取指定撥號連接的撥號參數

        dwResult := RasGetEntryDialParams( ''

        @RASDIALPARAMSData

        NeedPWD );


        if dwResult <> 0 then //獲取指定撥號連接的撥號參數失敗

        memo1.lines.add( '獲取'+StrPAS(RASDIALPARAMSData.szEntryName )+'撥號參數失敗:'

        + GetRasError( dwResult ))

        else

        begin//顯示指定撥號連接的撥號參數

        memo1.lines.add( StrPAS(RASDIALPARAMSData.szEntryName )+'撥號參數如下');

        memo1.lines.add( '用戶名稱:' + StrPAS(RASDIALPARAMSData.szUserName ));

        memo1.lines.add( '用戶密碼:' + StrPAS(RASDIALPARAMSData.szPassword ));

        memo1.lines.add( '域 名:' + StrPAS(RASDIALPARAMSData.szDomain ));

        memo1.lines.add( '回叫號碼:' + StrPAS(RASDIALPARAMSData.szCallbackNumber ));

        memo1.lines.add( '撥號號碼:' + StrPAS(RASDIALPARAMSData.szPhoneNumber ));

        end;

        end;

        2、設置撥號連接的撥號參數

        設置撥號連接的撥號參數RasAPI函數為RasSetEntryDialParams,其函數原型為:

        function RasSetEntryDialParams(

        lpszPhonebook: pchar;//電話本名稱,在Win9X下無作用

        可為空字符串

        pRASDIALPARAMS:LPRASDIALPARAMS;//撥號參數,是一個RASDIALPARAMS類型的指針

        var lpfPassword : WordBool//是否刪除用戶密碼

        ) : DWORD; stdcall;

        function RasSetEntryDialParams;external RasApiDll name 'RasSetEntryDialParamsA';

        參數pRASDIALPARAMS的說明同RasGetEntryDialParams.

        參數lpfPassword的含義與RasGetEntryDialParams不同,在此表示是否刪除用戶密碼,為

        TRUE時將原來的用戶密碼刪除.


        函數返回值為0表示執行成功;否則為錯誤代碼.

        下面是一個應用例子,設置指定撥號連接的撥號參數.

        var

        dwResult : DWORD;

        RASDIALPARAMSData : RASDIALPARAMS;

        RemovePWD : WordBool;

        begin

        //指定撥號連接的撥號參數

        with RASDIALPARAMSData do

        begin

        dwSize := sizeof( RASDIALPARAMS );//結構大小

        szEntryName := '163';//指定撥號連接的名稱

        szUserName := 'MyName';//指定用戶名稱

        szPassword := 'MyPassword';//指定用戶密碼

        szDomain := 'MyDomain';//指定域名

        szCallbackNumber := '';//指定回叫號碼

        szPhoneNumber := '';//指定撥號號碼

        end;

        RemovePWD := false;//不需要刪除用戶密碼


        //設置指定撥號連接的撥號參數

        dwResult := RasSetEntryDialParams( ''

        @RASDIALPARAMSData

        RemovePWD );


        if dwResult <> 0 then //設置指定撥號連接的撥號參數失敗

        memo1.lines.add( '設置'+StrPAS(RASDIALPARAMSData.szEntryName )+'撥號參數失敗:' + GetRasError( dwResult ))

        else

        begin//顯示指定撥號連接的撥號參數

        memo1.lines.add( StrPAS(RASDIALPARAMSData.szEntryName )+'撥號參數設置成功');

        memo1.lines.add( '用戶名稱:' + StrPAS(RASDIALPARAMSData.szUserName ));

        memo1.lines.add( '用戶密碼:' + StrPAS(RASDIALPARAMSData.szPassword ));

        memo1.lines.add( '域 名:' + StrPAS(RASDIALPARAMSData.szDomain ));

        memo1.lines.add( '回叫號碼:' + StrPAS(RASDIALPARAMSData.szCallbackNumber ));

        memo1.lines.add( '撥號號碼:' + StrPAS(RASDIALPARAMSData.szPhoneNumber ));

        end;

        end;


        四、用指定的撥號連接撥號、掛斷指定的撥號連接

        1、用指定的撥號連接撥號

        撥號有兩種方法,一種是調用撥號網絡中的撥號程序,就象用戶自己用鼠標雙擊撥號連接名稱一 樣,用戶可以修改撥號號碼、用戶名稱和用戶密碼,最后由撥號網絡來完成撥號過程;另一個方法則 是調用RasAPI函數.

        (1)用撥號網絡中的撥號程序

        在程序中可以用如下代碼:

        winexec('rundll32.exe rnaui.dll

        RnaDial 169'

        SW_SHOWNORMAL);

        其中字符串中的最后一個參數"169"為撥號連接的名稱。

        (2)用RasAPI函數撥號 用撥號連接撥號的RasAPI函數為RasDial,其函數原型為:

        function RasDial(

        pRasDialExtensions : LPRASDIALEXTENSIONS;//在WIN9X下無用

        可設置為NIL

        lpszPhonebook : PChar;//電話本名稱,在Win9X下無作用

        可為空字符串

        lpRasDialParams : LPRASDIALPARAMS;//撥號參數

        dwNotifierType : DWORD;//消息通知方式

        handle : TRasDialFunc;//消息處理事件

        var lphRasConn : DWORD//返回的成功連接的連接句柄

        ) : DWORD; stdcall;

        function RasDial;external RasApiDll name 'RasDialA';


        參數pRASDIALPARAMS的說明同RasGetEntryDialParams.

        參數dwNotifierType表示消息通知方式.在撥號過程中,系統發出撥號事件消息可以通知撥號 進度,因而需要提供接受消息的方式和處理消息的函數.當其值為$FFFFFFFF時,則參數handle被 視為一個窗口的句柄,事件消息被發生該窗口處理;當其值為0時,handle被視為TRasDialFunc類型 的函數的指針;當其值為1時,handle被視為TRasDialFunc1類型的函數的指針.

        參數handle表示消息處理函數指針,其類型可以THandle、TRasDialFunc、TRasDialFunc1.當該 參數不為NULL或NIL時,其代表的消息處理函數指針將接受撥號進度通知消息;為NIL時,撥號過程由異步方式變為同步方式,直到撥號過程成功或失敗后RasDial函數才返回.詳細可參見Delphi幫助文件中關于RasDial函數的幫助。

        當撥號連接成功時,lphRasConn將表示其連接句柄.


        函數返回值為0表示執行成功;否則為錯誤代碼.

        下面是一個應用例子,按指定的撥號參數撥號.


        var

        RASDIALPARAMSData : RASDIALPARAMS;

        dwResult : DWord;

        RasCon : DWord;

        begin

        //指定撥號連接的撥號參數

        with RASDIALPARAMSData do

        begin

        dwSize := sizeof( RASDIALPARAMS );//結構大小

        szEntryName := '163';//指定撥號連接的名稱

        szUserName := 'MyName';//指定用戶名稱

        szPassword := 'MyPassword';//指定用戶密碼

        szDomain := 'MyDomain';//指定域名

        szCallbackNumber := '';//指定回叫號碼

        szPhoneNumber := '';//指定撥號號碼

        end;


        //用指定的撥號參數撥號,采用同步撥號方式

        dwResult := RasDial( NIL

        ''

        @RASDIALPARAMSData

        0

        NIL

        RasCon );


        if dwResult <> 0 then //設置指定撥號連接的撥號參數失敗

        memo1.lines.add( '用'+StrPAS(RASDIALPARAMSData.szEntryName )+'撥號失敗:'

        + GetRasError( dwResult ))

        else

        memo1.lines.add( '用'+StrPAS(RASDIALPARAMSData.szEntryName )+'撥號成功!' );

        end;


        2、掛斷指定的撥號連接

        掛斷撥號連接的RasAPI函數為RasHangUp,其函數原型為:

        function RasHangUp(

        hRasConn : DWORD//要掛斷的撥號連接的句柄

        ) : DWORD; stdcall;

        function RasHangUp;external RasApiDll name 'RasHangUpA';

        函數返回值為0表示執行成功;否則為錯誤代碼.

        下面是一個應用例子,掛斷由RasDial建立的撥號連接.


        //掛斷由RasDial建立的撥號連接

        dwResult := RasHangUp( RasCon );

        if dwResult <> 0 then //掛斷失敗

        memo1.lines.add( '掛斷失敗:' + GetRasError( dwResult ))

        else

        memo1.lines.add( '掛斷成功!');


        五、獲取當前活動的連接及其連接狀態

        1、獲取當前活動的連接

        獲取當前活動的連接的RasAPI函數為RasEnumConnections,其函數原型為:

        DWORD RasEnumConnections(
          LPRASCONN lprasconn,     // buffer to receive connections
                                   //  data
          LPDWORD lpcb,            // size in bytes of buffer
          LPDWORD lpcConnections   // number of connections written
                                   //  to buffer
        ); 

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

        本類教程下載

        系統下載排行

        主站蜘蛛池模板: 噼里啪啦免费观看高清动漫4| 无码国产精品一区二区免费3p| 天天看免费高清影视| 亚洲va在线va天堂va手机| 久久久久久久岛国免费播放 | 免费人成黄页在线观看日本| 亚洲中文字幕无码久久综合网| 一级做受视频免费是看美女 | 亚洲一久久久久久久久| 日韩免费a级毛片无码a∨| 亚洲色大成网站www永久男同| 性感美女视频免费网站午夜 | 亚洲av成人一区二区三区观看在线 | 中文字幕免费在线看| 亚洲精品无码Av人在线观看国产| 日韩精品无码免费专区午夜 | 亚洲无圣光一区二区| 好男人www免费高清视频在线| 亚洲色大18成人网站WWW在线播放| 女人被男人桶得好爽免费视频| 久久水蜜桃亚洲AV无码精品| 亚洲精品人成无码中文毛片| 国产一级黄片儿免费看| 亚洲一区二区成人| 黄页网站在线观看免费高清| 国产青草亚洲香蕉精品久久| 亚洲熟妇av一区二区三区漫画| 日本卡1卡2卡三卡免费| 亚洲中文字幕久久无码| 亚洲精品国产成人影院| 国产精品免费福利久久| 亚洲精品国产精品国自产网站| 国产国产成年年人免费看片| 中文字幕在线免费看线人| 亚洲福利电影一区二区?| 精品久久久久久久免费加勒比| aa午夜免费剧场| 精品亚洲AV无码一区二区三区| 四虎亚洲国产成人久久精品| 99久久久国产精品免费蜜臀| 久久久亚洲精华液精华液精华液|