굿

로컬 IP 가지고 오기

· 14년 전 · 1347
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,339
14년 전 조회 1,042
14년 전 조회 1,466
14년 전 조회 1,633
14년 전 조회 834
14년 전 조회 2,078
14년 전 조회 2,053
14년 전 조회 1,643
14년 전 조회 1,595
14년 전 조회 1,106
14년 전 조회 1,588
14년 전 조회 1,519
14년 전 조회 1,228
14년 전 조회 963
14년 전 조회 2,708
14년 전 조회 2,017
14년 전 조회 1,375
14년 전 조회 2,031
14년 전 조회 910
14년 전 조회 1,010
14년 전 조회 1,635
14년 전 조회 1,740
14년 전 조회 1,338
14년 전 조회 1,029
14년 전 조회 1,196
14년 전 조회 1,129
14년 전 조회 1,981
14년 전 조회 2,107
14년 전 조회 1,978
14년 전 조회 1,114
14년 전 조회 1,684
14년 전 조회 1,738
14년 전 조회 1,836
14년 전 조회 3,607
14년 전 조회 1,162
14년 전 조회 1,961
14년 전 조회 878
14년 전 조회 1,016
14년 전 조회 858
14년 전 조회 1,315
14년 전 조회 1,769
14년 전 조회 1,307
14년 전 조회 1,159
14년 전 조회 815
14년 전 조회 1,795
14년 전 조회 1,365
14년 전 조회 926
14년 전 조회 2,311
14년 전 조회 1,427
14년 전 조회 1,348
14년 전 조회 883
14년 전 조회 1,753
14년 전 조회 2,722
14년 전 조회 1,222
14년 전 조회 616
14년 전 조회 2,181
14년 전 조회 1,940
14년 전 조회 887
14년 전 조회 1,471
14년 전 조회 1,645
14년 전 조회 1,503
14년 전 조회 865
14년 전 조회 832
14년 전 조회 1,138
14년 전 조회 1,466
14년 전 조회 1,319
14년 전 조회 1,002
14년 전 조회 1,432
14년 전 조회 1,275
14년 전 조회 1,547
14년 전 조회 999
14년 전 조회 1,235
14년 전 조회 1,036
14년 전 조회 1,393
14년 전 조회 859
14년 전 조회 2,255
14년 전 조회 1,463
14년 전 조회 3,065
14년 전 조회 1,438
14년 전 조회 1,210
14년 전 조회 1,253
14년 전 조회 1,254
14년 전 조회 722
14년 전 조회 984
14년 전 조회 1,023
14년 전 조회 2,479
14년 전 조회 1,116
14년 전 조회 3,479
14년 전 조회 952
14년 전 조회 786
14년 전 조회 851
14년 전 조회 1,836
14년 전 조회 1,454
14년 전 조회 1,268
14년 전 조회 1,331
14년 전 조회 1,259
14년 전 조회 1,360
14년 전 조회 1,017
14년 전 조회 623
14년 전 조회 1,135
🐛 버그신고