RT

解决方案 »

  1.   

    '枚举网络连接
    Private Const RAS_MaxDeviceType = 16
    Private Const RAS95_MaxDeviceName = 128
    Private Const RAS95_MaxEntryName = 256
    Private Type RASCONN95
        dwSize As Long
        hRasConn As Long
        szEntryName(RAS95_MaxEntryName) As Byte
        szDeviceType(RAS_MaxDeviceType) As Byte
        szDeviceName(RAS95_MaxDeviceName) As Byte
    End Type
    Private Type RASENTRYNAME95
        dwSize As Long
        szEntryName(RAS95_MaxEntryName) As Byte
    End Type
    Private Declare Function RasEnumConnections Lib "rasapi32.dll" Alias "RasEnumConnectionsA" (lprasconn As Any, lpcb As Long, lpcConnections As Long) As Long
    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 Long) As Long
    Private Declare Function RasHangUp Lib "rasapi32.dll" Alias "RasHangUpA" (ByVal hRasConn As Long) As LongPublic Sub EnumConnectName(Value() As String)
        Dim s As Long, l As Long, ln As Long, a As String
        ReDim r(255) As RASENTRYNAME95    r(0).dwSize = 264
        s = 256 * r(0).dwSize
        l = RasEnumEntries(vbNullString, vbNullString, r(0), s, ln)
        ReDim Value(ln - 1)
        For l = 0 To ln - 1
            a = StrConv(r(l).szEntryName(), vbUnicode)
            Value(l) = Left$(a$, InStr(a$, Chr$(0)) - 1)
        Next
    End Sub
      

  2.   

    Value() As String 是什么?
      

  3.   

    使用方法:
    dim Value() As String
    EnumConnectName Value在Value中就保存了所有的拨号连接名称