굿

로컬 IP 가지고 오기

· 14년 전 · 1372
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,366
14년 전 조회 1,071
14년 전 조회 1,492
14년 전 조회 1,661
14년 전 조회 865
14년 전 조회 2,107
14년 전 조회 2,083
14년 전 조회 1,668
14년 전 조회 1,624
14년 전 조회 1,136
14년 전 조회 1,617
14년 전 조회 1,548
14년 전 조회 1,257
14년 전 조회 990
14년 전 조회 2,736
14년 전 조회 2,050
14년 전 조회 1,409
14년 전 조회 2,061
14년 전 조회 936
14년 전 조회 1,039
14년 전 조회 1,666
14년 전 조회 1,764
14년 전 조회 1,371
14년 전 조회 1,060
14년 전 조회 1,225
14년 전 조회 1,161
14년 전 조회 2,009
14년 전 조회 2,134
14년 전 조회 2,012
14년 전 조회 1,140
14년 전 조회 1,713
14년 전 조회 1,766
14년 전 조회 1,865
14년 전 조회 3,641
14년 전 조회 1,191
14년 전 조회 1,987
14년 전 조회 908
14년 전 조회 1,042
14년 전 조회 887
14년 전 조회 1,339
14년 전 조회 1,796
14년 전 조회 1,330
14년 전 조회 1,186
14년 전 조회 842
14년 전 조회 1,819
14년 전 조회 1,396
14년 전 조회 956
14년 전 조회 2,339
14년 전 조회 1,452
14년 전 조회 1,373
14년 전 조회 911
14년 전 조회 1,784
14년 전 조회 2,755
14년 전 조회 1,247
14년 전 조회 646
14년 전 조회 2,205
14년 전 조회 1,968
14년 전 조회 912
14년 전 조회 1,495
14년 전 조회 1,668
14년 전 조회 1,529
14년 전 조회 890
14년 전 조회 861
14년 전 조회 1,164
14년 전 조회 1,493
14년 전 조회 1,349
14년 전 조회 1,027
14년 전 조회 1,451
14년 전 조회 1,300
14년 전 조회 1,576
14년 전 조회 1,022
14년 전 조회 1,260
14년 전 조회 1,060
14년 전 조회 1,422
14년 전 조회 885
14년 전 조회 2,286
14년 전 조회 1,488
14년 전 조회 3,085
14년 전 조회 1,465
14년 전 조회 1,241
14년 전 조회 1,284
14년 전 조회 1,283
14년 전 조회 749
14년 전 조회 1,005
14년 전 조회 1,055
14년 전 조회 2,509
14년 전 조회 1,142
14년 전 조회 3,506
14년 전 조회 976
14년 전 조회 813
14년 전 조회 881
14년 전 조회 1,863
14년 전 조회 1,483
14년 전 조회 1,300
14년 전 조회 1,353
14년 전 조회 1,282
14년 전 조회 1,388
14년 전 조회 1,045
14년 전 조회 648
14년 전 조회 1,160