굿

로컬 IP 가지고 오기

· 14년 전 · 1425
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,421
14년 전 조회 1,121
14년 전 조회 1,545
14년 전 조회 1,720
14년 전 조회 925
14년 전 조회 2,166
14년 전 조회 2,137
14년 전 조회 1,719
14년 전 조회 1,685
14년 전 조회 1,196
14년 전 조회 1,677
14년 전 조회 1,603
14년 전 조회 1,315
14년 전 조회 1,050
14년 전 조회 2,792
14년 전 조회 2,105
14년 전 조회 1,460
14년 전 조회 2,113
14년 전 조회 991
14년 전 조회 1,087
14년 전 조회 1,723
14년 전 조회 1,818
14년 전 조회 1,415
14년 전 조회 1,115
14년 전 조회 1,291
14년 전 조회 1,214
14년 전 조회 2,062
14년 전 조회 2,194
14년 전 조회 2,070
14년 전 조회 1,197
14년 전 조회 1,760
14년 전 조회 1,819
14년 전 조회 1,919
14년 전 조회 3,703
14년 전 조회 1,243
14년 전 조회 2,040
14년 전 조회 962
14년 전 조회 1,092
14년 전 조회 942
14년 전 조회 1,397
14년 전 조회 1,852
14년 전 조회 1,393
14년 전 조회 1,240
14년 전 조회 902
14년 전 조회 1,871
14년 전 조회 1,448
14년 전 조회 1,002
14년 전 조회 2,396
14년 전 조회 1,501
14년 전 조회 1,426
14년 전 조회 960
14년 전 조회 1,841
14년 전 조회 2,808
14년 전 조회 1,277
14년 전 조회 699
14년 전 조회 2,250
14년 전 조회 2,024
14년 전 조회 970
14년 전 조회 1,546
14년 전 조회 1,720
14년 전 조회 1,589
14년 전 조회 945
14년 전 조회 904
14년 전 조회 1,230
14년 전 조회 1,547
14년 전 조회 1,406
14년 전 조회 1,081
14년 전 조회 1,503
14년 전 조회 1,358
14년 전 조회 1,632
14년 전 조회 1,086
14년 전 조회 1,319
14년 전 조회 1,116
14년 전 조회 1,476
14년 전 조회 946
14년 전 조회 2,351
14년 전 조회 1,541
14년 전 조회 3,138
14년 전 조회 1,520
14년 전 조회 1,292
14년 전 조회 1,335
14년 전 조회 1,332
14년 전 조회 808
14년 전 조회 1,055
14년 전 조회 1,105
14년 전 조회 2,572
14년 전 조회 1,192
14년 전 조회 3,570
14년 전 조회 1,027
14년 전 조회 862
14년 전 조회 932
14년 전 조회 1,915
14년 전 조회 1,539
14년 전 조회 1,349
14년 전 조회 1,408
14년 전 조회 1,335
14년 전 조회 1,447
14년 전 조회 1,099
14년 전 조회 703
14년 전 조회 1,214