굿

로컬 IP 가지고 오기

· 14년 전 · 1407
Option Explicit
'=========// IP 주소 가져오기 //==========================================================
Public Const ERROR_SUCCESS As Long = 0
Public Const MAX_ADAPTER_NAME_LENGTH As Long = 256
Public Const MAX_ADAPTER_DESCRipTION_LENGTH As Long = 128
Public Const MAX_ADAPTER_ADDRESS_LENGTH As Long = 8


Public Type ip_ADDRESS_STRING
ipAddr(0 To 15) As Byte
End Type


Public Type ip_MASK_STRING
ipMask(0 To 15) As Byte
End Type



Public Type ip_ADDR_STRING
dwNext As Long
ipAddress As ip_ADDRESS_STRING
ipMask As ip_MASK_STRING
dwContext As Long
End Type


Public Type ip_ADAPTER_INFO
dwNext As Long
ComboIndex As Long 'reserved
sAdapterName(0 To (MAX_ADAPTER_NAME_LENGTH + 3)) As Byte
sDescription(0 To (MAX_ADAPTER_DESCRipTION_LENGTH + 3)) As Byte
dwAddressLength As Long
sipAddress(0 To (MAX_ADAPTER_ADDRESS_LENGTH - 1)) As Byte
dwIndex As Long
uType As Long
uDhcpEnabled As Long
CurrentipAddress As Long
ipAddressList As ip_ADDR_STRING
GatewayList As ip_ADDR_STRING
DhcpServer As ip_ADDR_STRING
bHaveWins As Long
PrimaryWinsServer As ip_ADDR_STRING
SecondaryWinsServer As ip_ADDR_STRING
LeaseObtained As Long
LeaseExpires As Long
End Type


Public Declare Function GetAdaptersInfo Lib "iphlpapi.dll" _
(pTcpTable As Any, _
pdwSize As Long) As Long


Public Declare Sub CopyMemory Lib "kernel32" _
Alias "RtlMoveMemory" _
(dst As Any, _
src As Any, _
ByVal bcount As Long)


Public Declare Function DeleteUrlCacheEntry Lib "Wininet.dll" _
Alias "DeleteUrlCacheEntryA" _
(ByVal lpszUrlName As String) As Long


Public Declare Function lstrlenW Lib "kernel32" _
(ByVal lpString As Long) As Long



Public Function LocalipAddress() As String

On Error Resume Next

Dim cbRequired As Long
Dim buff() As Byte
Dim ptr1 As Long
Dim sipAddr As String
Dim Adapter As ip_ADAPTER_INFO

LocalipAddress = ""

Call GetAdaptersInfo(ByVal 0&, cbRequired)

If cbRequired > 0 Then
ReDim buff(0 To cbRequired - 1) As Byte
If GetAdaptersInfo(buff(0), cbRequired) = ERROR_SUCCESS Then
ptr1 = VarPtr(buff(0))
Do While (ptr1 <> 0)
CopyMemory Adapter, ByVal ptr1, LenB(Adapter)
With Adapter
sipAddr = TrimNull(StrConv(.ipAddressList.ipAddress.ipAddr, vbUnicode))
If Len(sipAddr) > 0 Then Exit Do
ptr1 = .dwNext
End With 'With Adapter
Loop 'Do While (ptr1 <> 0
End If 'If GetAdaptersInfo
End If 'If cbRequired > 0

LocalipAddress = sipAddr

End Function

Public Function TrimNull(startstr As String) As String

TrimNull = Left$(startstr, lstrlenW(StrPtr(startstr)))

End Function<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 16:46:12 기타에서 이동 됨]</div>
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
14년 전 조회 1,403
14년 전 조회 1,104
14년 전 조회 1,524
14년 전 조회 1,703
14년 전 조회 908
14년 전 조회 2,149
14년 전 조회 2,122
14년 전 조회 1,699
14년 전 조회 1,664
14년 전 조회 1,178
14년 전 조회 1,654
14년 전 조회 1,585
14년 전 조회 1,291
14년 전 조회 1,029
14년 전 조회 2,774
14년 전 조회 2,087
14년 전 조회 1,447
14년 전 조회 2,092
14년 전 조회 975
14년 전 조회 1,071
14년 전 조회 1,703
14년 전 조회 1,808
14년 전 조회 1,401
14년 전 조회 1,098
14년 전 조회 1,269
14년 전 조회 1,195
14년 전 조회 2,046
14년 전 조회 2,170
14년 전 조회 2,045
14년 전 조회 1,176
14년 전 조회 1,747
14년 전 조회 1,802
14년 전 조회 1,906
14년 전 조회 3,683
14년 전 조회 1,227
14년 전 조회 2,024
14년 전 조회 944
14년 전 조회 1,077
14년 전 조회 925
14년 전 조회 1,371
14년 전 조회 1,836
14년 전 조회 1,369
14년 전 조회 1,221
14년 전 조회 885
14년 전 조회 1,854
14년 전 조회 1,433
14년 전 조회 986
14년 전 조회 2,378
14년 전 조회 1,483
14년 전 조회 1,408
14년 전 조회 947
14년 전 조회 1,819
14년 전 조회 2,791
14년 전 조회 1,265
14년 전 조회 677
14년 전 조회 2,238
14년 전 조회 2,009
14년 전 조회 950
14년 전 조회 1,530
14년 전 조회 1,708
14년 전 조회 1,567
14년 전 조회 920
14년 전 조회 892
14년 전 조회 1,206
14년 전 조회 1,526
14년 전 조회 1,380
14년 전 조회 1,061
14년 전 조회 1,487
14년 전 조회 1,330
14년 전 조회 1,614
14년 전 조회 1,067
14년 전 조회 1,298
14년 전 조회 1,095
14년 전 조회 1,463
14년 전 조회 919
14년 전 조회 2,325
14년 전 조회 1,523
14년 전 조회 3,119
14년 전 조회 1,501
14년 전 조회 1,274
14년 전 조회 1,321
14년 전 조회 1,309
14년 전 조회 788
14년 전 조회 1,034
14년 전 조회 1,090
14년 전 조회 2,553
14년 전 조회 1,172
14년 전 조회 3,544
14년 전 조회 1,011
14년 전 조회 841
14년 전 조회 918
14년 전 조회 1,896
14년 전 조회 1,515
14년 전 조회 1,334
14년 전 조회 1,392
14년 전 조회 1,317
14년 전 조회 1,428
14년 전 조회 1,080
14년 전 조회 681
14년 전 조회 1,195