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 12.683 mal aufgerufen.
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv (einschl. Beispielprojekt!) Ein absolutes Muss - Mehr als 650 MByte geballtes Wissen! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - Online-Update-Funktion u.v.m. |
TOP Entwickler-Paket ![]() TOP-Preis!! Mit der Developer CD erhalten Sie insgesamt 25 Entwickler- komponenten und Windows-DLLs. Die Einzelkomponenten haben einen Gesamtwert von 1524.50 EUR... Buchempfehlung Tipp des Monats Dieter Otter 2-dimensionales Array nach beliebiger Spalte sortieren Mit dieser Funktion lässt sich ein 2-dimensionales Array beliebiger Daten nach einer bestimmten Spalte sortieren sevEingabe 2.0 ![]() Einfach stark! Ein einziges Eingabe-Control für alle benötigten Eingabetypen und -formate, inkl. Kalender-, Taschenrechner und Floskelfunktion, mehrspaltige ComboBox mit DB-Anbindung, ImageComboBox u.v.m. |
||||||||||||||||
|
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. |
|||||||||||||||||


Internet-Verbindung trennen



