In unserem vorigen Tipp haben wir Ihnen gezeigt, wie man eine Internet-Verbindung programmgesteuert starten kann. Unser heutiger Tipp zeigt den umgekehrten Weg, d.h. Sie können entweder eine bestimmte oder oder alle aktiven Internet-Verbindungen programmgesteuert trennen. ' zunächst die benötigten API-Deklarationen Private Declare Function InternetGetConnectedState Lib "wininet.dll" ( _ ByRef lpdwFlags As Long, _ ByVal dwReserved As Long) As Long Private Declare Function InternetHangUp Lib "wininet.dll" ( _ ByVal dwConnection As Long, _ ByVal dwReserved As Long) As Long Private Const DIAL_FORCE_ONLINE = 1 Private Const DIAL_FORCE_UNATTENDED = 2 Private Type RASCONN dwSize As Long hRasConn As Long szEntryName(256) As Byte szDeviceType(16) As Byte szDeviceName(128) As Byte End Type Private Declare Function RasEnumConnectionsA Lib "RasApi32.DLL" ( _ lpRasConn As Any, _ lbcp As Long, _ lbcConnections As Long) As Long Prüfen auf aktive Internet-Verbindungen ' Prüfen auf aktive Internet-Verbindungen Public Function RASIsConnected(ByVal hWnd As Long, _ Optional ByVal DFÜName As String = "") As Long Dim nConnected As Long Dim dwFlags As Long Dim lpRasConn(255) As RASCONN Dim lpcConnections As Long Dim lpcb As Long Dim i As Long Dim hRasConn As Long Dim szEntryName As String ' Anzahl aktiver Verbindungen nConnected = InternetGetConnectedState(dwFlags, 0) If (nConnected) Then ' Handle der Verbindung ermitteln lpRasConn(0).dwSize = 412 lpcb = 256 * lpRasConn(0).dwSize RasEnumConnectionsA lpRasConn(0), lpcb, lpcConnections If DFÜName <> "" Then ' Prüfen, ob "DFÜName" in der Auflistung vorhanden For i = 0 To lpcConnections - 1 szEntryName = StrConv(lpRasConn(i).szEntryName, _ vbUnicode) szEntryName = Left$(szEntryName, _ InStr(szEntryName, vbNullChar) - 1) If szEntryName = DFÜName Then hRasConn = lpRasConn(i).hRasConn Exit For End If Next i Else ' Handle der ersten Verbindung hRasConn = lpRasConn(0).hRasConn End If End If RASIsConnected = hRasConn End Function Online-Verbindung trennen ' (bestimmte/alle) Internet-Verbindung(en) trennen Public Function RASDisconnect(ByVal hWnd As Long, _ Optional ByVal DFÜName As String = "", _ Optional ByVal DisconnectAll As Boolean) As Boolean Dim nConnected As Long Dim dwFlags As Long Dim lpRasConn(255) As RASCONN Dim lpcConnections As Long Dim lpcb As Long Dim hRasConn As Long Dim i As Long Dim Result As Boolean Result = False If Not DisconnectAll Then ' (bestimmte) Verbindung trennen hRasConn = RASIsConnected(hWnd, DFÜName) If hRasConn <> 0 Then Result = (InternetHangUp(hRasConn, 0) = 0) End If Else ' Alle Verbindungen trennen nConnected = InternetGetConnectedState(dwFlags, 0) If (nConnected) Then lpRasConn(0).dwSize = 412 lpcb = 256 * lpRasConn(0).dwSize RasEnumConnectionsA lpRasConn(0), lpcb, lpcConnections Result = True For i = 0 To lpcConnections - 1 hRasConn = lpRasConn(i).hRasConn If InternetHangUp(hRasConn, 0) <> 0 Then _ Result = False Next i End If End If RASDisconnect = Result End Function Dieser Tipp wurde bereits 28.203 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
sevOutBar 4.0 Vertikale Menüleisten á la Outlook Erstellen von Outlook ähnlichen Benutzer- interfaces - mit beliebig vielen Gruppen und Symboleinträgen. Moderner OfficeXP-Style mit Farbverläufen, Balloon-Tips, u.v.m. Tipp des Monats April 2024 Skyfloy Chart von Microsoft und dazu noch gratis Tutorial für Microsoft Chart Controls für Microsoft .NET Framework 3.5 Access-Tools Vol.1 Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |