굿

로컬 IP 가지고 오기

· 14년 전 · 1352
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,341
14년 전 조회 1,043
14년 전 조회 1,470
14년 전 조회 1,637
14년 전 조회 836
14년 전 조회 2,079
14년 전 조회 2,057
14년 전 조회 1,645
14년 전 조회 1,596
14년 전 조회 1,109
14년 전 조회 1,592
14년 전 조회 1,522
14년 전 조회 1,232
14년 전 조회 967
14년 전 조회 2,712
14년 전 조회 2,023
14년 전 조회 1,379
14년 전 조회 2,034
14년 전 조회 912
14년 전 조회 1,012
14년 전 조회 1,637
14년 전 조회 1,741
14년 전 조회 1,341
14년 전 조회 1,035
14년 전 조회 1,198
14년 전 조회 1,130
14년 전 조회 1,985
14년 전 조회 2,110
14년 전 조회 1,981
14년 전 조회 1,117
14년 전 조회 1,688
14년 전 조회 1,741
14년 전 조회 1,838
14년 전 조회 3,610
14년 전 조회 1,164
14년 전 조회 1,965
14년 전 조회 882
14년 전 조회 1,018
14년 전 조회 861
14년 전 조회 1,320
14년 전 조회 1,773
14년 전 조회 1,311
14년 전 조회 1,161
14년 전 조회 821
14년 전 조회 1,799
14년 전 조회 1,371
14년 전 조회 929
14년 전 조회 2,314
14년 전 조회 1,428
14년 전 조회 1,353
14년 전 조회 885
14년 전 조회 1,758
14년 전 조회 2,726
14년 전 조회 1,225
14년 전 조회 619
14년 전 조회 2,184
14년 전 조회 1,942
14년 전 조회 890
14년 전 조회 1,474
14년 전 조회 1,647
14년 전 조회 1,506
14년 전 조회 869
14년 전 조회 836
14년 전 조회 1,138
14년 전 조회 1,467
14년 전 조회 1,322
14년 전 조회 1,004
14년 전 조회 1,433
14년 전 조회 1,277
14년 전 조회 1,550
14년 전 조회 1,004
14년 전 조회 1,238
14년 전 조회 1,039
14년 전 조회 1,396
14년 전 조회 862
14년 전 조회 2,256
14년 전 조회 1,466
14년 전 조회 3,067
14년 전 조회 1,440
14년 전 조회 1,213
14년 전 조회 1,257
14년 전 조회 1,256
14년 전 조회 723
14년 전 조회 987
14년 전 조회 1,025
14년 전 조회 2,483
14년 전 조회 1,119
14년 전 조회 3,483
14년 전 조회 954
14년 전 조회 788
14년 전 조회 852
14년 전 조회 1,837
14년 전 조회 1,456
14년 전 조회 1,271
14년 전 조회 1,334
14년 전 조회 1,260
14년 전 조회 1,364
14년 전 조회 1,020
14년 전 조회 623
14년 전 조회 1,136
🐛 버그신고