굿

로컬 IP 가지고 오기

· 14년 전 · 1691
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,694
14년 전 조회 1,398
14년 전 조회 1,890
14년 전 조회 1,994
14년 전 조회 1,199
14년 전 조회 2,447
14년 전 조회 2,425
14년 전 조회 2,001
14년 전 조회 1,947
14년 전 조회 1,473
14년 전 조회 1,961
14년 전 조회 1,882
14년 전 조회 1,589
14년 전 조회 1,290
14년 전 조회 3,046
14년 전 조회 2,366
14년 전 조회 1,725
14년 전 조회 2,376
14년 전 조회 1,246
14년 전 조회 1,355
14년 전 조회 1,990
14년 전 조회 2,072
14년 전 조회 1,681
14년 전 조회 1,369
14년 전 조회 1,533
14년 전 조회 1,486
14년 전 조회 2,311
14년 전 조회 2,442
14년 전 조회 2,317
14년 전 조회 1,474
14년 전 조회 2,026
14년 전 조회 2,069
14년 전 조회 2,160
14년 전 조회 3,944
14년 전 조회 1,490
14년 전 조회 2,298
14년 전 조회 1,211
14년 전 조회 1,347
14년 전 조회 1,202
14년 전 조회 1,642
14년 전 조회 2,087
14년 전 조회 1,631
14년 전 조회 1,482
14년 전 조회 1,165
14년 전 조회 2,128
14년 전 조회 1,691
14년 전 조회 1,235
14년 전 조회 2,655
14년 전 조회 1,750
14년 전 조회 1,692
14년 전 조회 1,207
14년 전 조회 2,086
14년 전 조회 3,054
14년 전 조회 1,479
14년 전 조회 927
14년 전 조회 2,458
14년 전 조회 2,209
14년 전 조회 1,166
14년 전 조회 1,734
14년 전 조회 1,918
14년 전 조회 1,774
14년 전 조회 1,117
14년 전 조회 1,106
14년 전 조회 1,407
14년 전 조회 1,732
14년 전 조회 1,588
14년 전 조회 1,274
14년 전 조회 1,690
14년 전 조회 1,523
14년 전 조회 1,818
14년 전 조회 1,282
14년 전 조회 1,517
14년 전 조회 1,297
14년 전 조회 1,658
14년 전 조회 1,127
14년 전 조회 2,533
14년 전 조회 1,737
14년 전 조회 3,319
14년 전 조회 1,706
14년 전 조회 1,471
14년 전 조회 1,538
14년 전 조회 1,517
14년 전 조회 975
14년 전 조회 1,233
14년 전 조회 1,298
14년 전 조회 2,763
14년 전 조회 1,404
14년 전 조회 3,762
14년 전 조회 1,218
14년 전 조회 1,052
14년 전 조회 1,132
14년 전 조회 2,118
14년 전 조회 1,729
14년 전 조회 1,539
14년 전 조회 1,593
14년 전 조회 1,516
14년 전 조회 1,625
14년 전 조회 1,280
14년 전 조회 887
14년 전 조회 1,394