w
VB6 判断网络是否正常类Option Explicit
VB6 判断网络是否正常类
'拨号/断网
VB6 判断网络是否正常类
Private Declare Function InternetDial Lib "wininet.dll" (ByVal hwndParent As Long, ByVal lpszConnectoid As String, ByVal dwFlags As Long, lpdwConnection As Long, ByVal dwReserved As LongAs Long
VB6 判断网络是否正常类
Private Declare Function InternetHangUp Lib "wininet.dll" (ByVal dwConnection As Long, ByVal dwReserved As LongAs Long
VB6 判断网络是否正常类
Private Declare Function InternetAutodial Lib "wininet.dll" (ByVal dwFlags As Long, ByVal dwReserved As LongAs Long
VB6 判断网络是否正常类
Private Declare Function InternetAutodialHangup Lib "wininet.dll" (ByVal dwReserved As LongAs Long
VB6 判断网络是否正常类
Private Const INTERNET_DIALSTATE_DISCONNECTED = 1
VB6 判断网络是否正常类
Private Const INTERNET_AUTODIAL_FORCE_ONLINE = 1
VB6 判断网络是否正常类
Private Const INTERNET_AUTODIAL_FORCE_UNATTENDED = 2
VB6 判断网络是否正常类
Private Const INTERNET_DIAL_UNATTENDED = &H8000
VB6 判断网络是否正常类
Private Handle As Long
VB6 判断网络是否正常类
VB6 判断网络是否正常类
'网络状态
VB6 判断网络是否正常类
Private Declare Function InternetGetConnectedStateEx Lib "wininet.dll" Alias "InternetGetConnectedStateExA" (ByRef lpdwFlags As Long, ByVal lpszConnectionName As String, ByVal dwNameLen As Long, ByVal dwReserved As LongAs Long
VB6 判断网络是否正常类
Private Declare Function InternetGetConnectedState Lib "wininet.dll" (ByRef dwFlags As Long, ByVal dwReserved As LongAs Long
VB6 判断网络是否正常类
Private Const INTERNET_CONNECTION_MODEM As Long = &H1      '本系统使用调制解调器与因特网相连
VB6 判断网络是否正常类
Private Const INTERNET_CONNECTION_LAN As Long = &H2        '本系统通过LAN与因特网相连
VB6 判断网络是否正常类
Private Const INTERNET_CONNECTION_PROXY As Long = &H4      '本系统使用proxy代理服务器与因特网相连
VB6 判断网络是否正常类
Private Const INTERNET_CONNECTION_MODEM_BUSY As Long = &H8 '未使用
VB6 判断网络是否正常类
Private Const INTERNET_RAS_INSTALLED As Long = &H10
VB6 判断网络是否正常类
Private Const INTERNET_CONNECTION_OFFLINE As Long = &H20
VB6 判断网络是否正常类
Private Const INTERNET_CONNECTION_CONFIGURED As Long = &H40
VB6 判断网络是否正常类
VB6 判断网络是否正常类
'枚举网络连接
VB6 判断网络是否正常类
Private Const RAS_MaxDeviceType = 16
VB6 判断网络是否正常类
Private Const RAS95_MaxDeviceName = 128
VB6 判断网络是否正常类
Private Const RAS95_MaxEntryName = 256
VB6 判断网络是否正常类
Private Type RASCONN95
VB6 判断网络是否正常类    dwSize 
As Long
VB6 判断网络是否正常类    hRasConn 
As Long
VB6 判断网络是否正常类    szEntryName(RAS95_MaxEntryName) 
As Byte
VB6 判断网络是否正常类    szDeviceType(RAS_MaxDeviceType) 
As Byte
VB6 判断网络是否正常类    szDeviceName(RAS95_MaxDeviceName) 
As Byte
VB6 判断网络是否正常类
End Type
VB6 判断网络是否正常类
Private Type RASENTRYNAME95
VB6 判断网络是否正常类    dwSize 
As Long
VB6 判断网络是否正常类    szEntryName(RAS95_MaxEntryName) 
As Byte
VB6 判断网络是否正常类
End Type
VB6 判断网络是否正常类
Private Declare Function RasEnumConnections Lib "rasapi32.dll" Alias "RasEnumConnectionsA" (lprasconn As Any, lpcb As Long, lpcConnections As LongAs Long
VB6 判断网络是否正常类
Private Declare Function RasEnumEntries Lib "rasapi32.dll" Alias "RasEnumEntriesA" (ByVal reserved As String, ByVal lpszPhonebook As String, lprasentryname As Any, lpcb As Long, lpcEntries As LongAs Long
VB6 判断网络是否正常类
Private Declare Function RasHangUp Lib "rasapi32.dll" Alias "RasHangUpA" (ByVal hRasConn As LongAs Long
VB6 判断网络是否正常类
VB6 判断网络是否正常类
'拨号
VB6 判断网络是否正常类
Public Function DialUp(LinkName As StringAs Boolean
VB6 判断网络是否正常类    InternetDial 
0, LinkName, INTERNET_AUTODIAL_FORCE_UNATTENDED, Handle, 0
VB6 判断网络是否正常类    DialUp 
= (Handle <> 0)
VB6 判断网络是否正常类
End Function
VB6 判断网络是否正常类
'断网
VB6 判断网络是否正常类
Public Sub HangUp()
VB6 判断网络是否正常类    
If Handle <> 0 Then
VB6 判断网络是否正常类        InternetHangUp Handle, 
0
VB6 判断网络是否正常类        Handle 
= 0
VB6 判断网络是否正常类    
End If
VB6 判断网络是否正常类
End Sub
VB6 判断网络是否正常类
VB6 判断网络是否正常类
VB6 判断网络是否正常类
'枚举网络连接
VB6 判断网络是否正常类
Public Sub EnumConnectName(Value() As String)
VB6 判断网络是否正常类    
Dim s As Long, l As Long, ln As Long, a As String
VB6 判断网络是否正常类    
ReDim r(255As RASENTRYNAME95
VB6 判断网络是否正常类
VB6 判断网络是否正常类    r(
0).dwSize = 264
VB6 判断网络是否正常类    s 
= 256 * r(0).dwSize
VB6 判断网络是否正常类    l 
= RasEnumEntries(vbNullString, vbNullString, r(0), s, ln)
VB6 判断网络是否正常类    
ReDim Value(ln - 1)
VB6 判断网络是否正常类    
For l = 0 To ln - 1
VB6 判断网络是否正常类        a 
= StrConv(r(l).szEntryName(), vbUnicode)
VB6 判断网络是否正常类        Value(l) 
= Left$(a$, InStr(a$, Chr$(0)) - 1)
VB6 判断网络是否正常类    
Next
VB6 判断网络是否正常类
End Sub
VB6 判断网络是否正常类
VB6 判断网络是否正常类
'判断是否在线
VB6 判断网络是否正常类
Public Function Online() As Boolean
VB6 判断网络是否正常类    Online 
= InternetGetConnectedState(0&0&)
VB6 判断网络是否正常类
End Function
VB6 判断网络是否正常类
'判断是否在线并返回连接方式
VB6 判断网络是否正常类
Public Property Get OnlineOfLinkName(LinkName As StringAs Boolean
VB6 判断网络是否正常类    LinkName 
= Space$(128)
VB6 判断网络是否正常类    OnlineOfLinkName 
= InternetGetConnectedStateEx(0, LinkName, 1280&)
VB6 判断网络是否正常类
End Property
VB6 判断网络是否正常类
VB6 判断网络是否正常类
'如果是通过LAN的连接,则返回True
VB6 判断网络是否正常类
Public Function IsNetConnectViaLAN() As Boolean
VB6 判断网络是否正常类    
Dim dwFlags As Long
VB6 判断网络是否正常类    
Call InternetGetConnectedState(dwFlags, 0&)
VB6 判断网络是否正常类    IsNetConnectViaLAN 
= dwFlags And INTERNET_CONNECTION_LAN
VB6 判断网络是否正常类
End Function
VB6 判断网络是否正常类
'如果是通过调制解调器的连接,则返回True
VB6 判断网络是否正常类
Public Function IsNetConnectViaModem() As Boolean
VB6 判断网络是否正常类    
Dim dwFlags As Long
VB6 判断网络是否正常类    
Call InternetGetConnectedState(dwFlags, 0&)
VB6 判断网络是否正常类    IsNetConnectViaModem 
= dwFlags And INTERNET_CONNECTION_MODEM
VB6 判断网络是否正常类
End Function
VB6 判断网络是否正常类
'如果是通过Proxy代理服务器的连接,则返回True
VB6 判断网络是否正常类
Public Function IsNetConnectViaProxy() As Boolean
VB6 判断网络是否正常类    
Dim dwFlags As Long
VB6 判断网络是否正常类    
Call InternetGetConnectedState(dwFlags, 0&)
VB6 判断网络是否正常类    IsNetConnectViaProxy 
= dwFlags And INTERNET_CONNECTION_PROXY
VB6 判断网络是否正常类
End Function
VB6 判断网络是否正常类
'如果已安装了RAS,则返回True
VB6 判断网络是否正常类
Public Function IsNetRASInstalled() As Boolean
VB6 判断网络是否正常类    
Dim dwFlags As Long
VB6 判断网络是否正常类    
Call InternetGetConnectedState(dwFlags, 0&)
VB6 判断网络是否正常类    IsNetRASInstalled 
= dwFlags And INTERNET_RAS_INSTALLED
VB6 判断网络是否正常类
End Function
VB6 判断网络是否正常类
'返回当前网络状态信息字符串
VB6 判断网络是否正常类
Public Function GetNetConnectString() As Boolean
VB6 判断网络是否正常类    
Dim dwFlags As Long
VB6 判断网络是否正常类    
Dim Msg As String
VB6 判断网络是否正常类    
If InternetGetConnectedState(dwFlags, 0&Then
VB6 判断网络是否正常类        
If dwFlags And INTERNET_CONNECTION_CONFIGURED Then
VB6 判断网络是否正常类            Msg 
= Msg & "系统配置了网络连接" & vbCrLf
VB6 判断网络是否正常类        
End If
VB6 判断网络是否正常类        
If dwFlags And INTERNET_CONNECTION_LAN Then
VB6 判断网络是否正常类            Msg 
= Msg & "系统通过局域网与因特网相连接"
VB6 判断网络是否正常类        
End If
VB6 判断网络是否正常类        
If dwFlags And INTERNET_CONNECTION_PROXY Then
VB6 判断网络是否正常类            Msg 
= Msg & "并使用了Proxy代理服务"
VB6 判断网络是否正常类        
Else: Msg = Msg & "."
VB6 判断网络是否正常类        
End If
VB6 判断网络是否正常类        
If dwFlags And INTERNET_CONNECTION_MODEM Then
VB6 判断网络是否正常类            Msg 
= Msg & "系统使用调制解调器与因特网相连接"
VB6 判断网络是否正常类        
End If
VB6 判断网络是否正常类        
If dwFlags And INTERNET_CONNECTION_OFFLINE Then
VB6 判断网络是否正常类            Msg 
= Msg & "系统当前处于离线状态"
VB6 判断网络是否正常类        
End If
VB6 判断网络是否正常类        
If dwFlags And INTERNET_CONNECTION_MODEM_BUSY Then
VB6 判断网络是否正常类            Msg 
= Msg & "系统的调制解调器未连接到因特网"
VB6 判断网络是否正常类        
End If
VB6 判断网络是否正常类        
If dwFlags And INTERNET_RAS_INSTALLED Then
VB6 判断网络是否正常类            Msg 
= Msg & "本系统安装了远程访问服务"
VB6 判断网络是否正常类        
End If
VB6 判断网络是否正常类        GetNetConnectString 
= True
VB6 判断网络是否正常类    
Else
VB6 判断网络是否正常类        Msg 
= "当前未与因特网相连"
VB6 判断网络是否正常类        GetNetConnectString 
= False
VB6 判断网络是否正常类    
End If
VB6 判断网络是否正常类
VB6 判断网络是否正常类
End Function
VB6 判断网络是否正常类
VB6 判断网络是否正常类
VB6 判断网络是否正常类
VB6 判断网络是否正常类

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-02-03
  • 2021-06-03
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2022-02-19
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-09-05
  • 2021-05-21
  • 2022-12-23
相关资源
相似解决方案