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.161 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. |
Neu! sevDTA 3.0 Pro SEPA mit Kontonummernprüfung Erstellen von SEPA-Dateien mit integriertem BIC-Verzeichnis und Konto- nummern-Prüfverfahren, so dass ungültige Bankdaten bereits im Vorfeld ermittelt werden können. Tipp des Monats März 2024 Dieter Otter UTF-8 Konvertierung von Dateien und Strings VB6 selbst verfügt über keine Funktionen zur UTF-8 Konvertierung von Daten. Mit Hilfe des ADODB.Stream-Objekts lassen sich diese fehlenden Funktionen aber schnell nachrüsten. TOP Entwickler-Paket TOP-Preis!! Mit der Developer CD erhalten Sie insgesamt 24 Entwickler- komponenten und Windows-DLLs. Die Einzelkomponenten haben einen Gesamtwert von 1605.50 EUR... |
||||||||||||||||
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. |