굿

로컬 IP 가지고 오기

· 14년 전 · 1733
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,741
14년 전 조회 1,446
14년 전 조회 1,927
14년 전 조회 2,035
14년 전 조회 1,253
14년 전 조회 2,492
14년 전 조회 2,477
14년 전 조회 2,060
14년 전 조회 1,994
14년 전 조회 1,530
14년 전 조회 2,016
14년 전 조회 1,939
14년 전 조회 1,636
14년 전 조회 1,333
14년 전 조회 3,092
14년 전 조회 2,410
14년 전 조회 1,773
14년 전 조회 2,419
14년 전 조회 1,280
14년 전 조회 1,410
14년 전 조회 2,032
14년 전 조회 2,123
14년 전 조회 1,726
14년 전 조회 1,418
14년 전 조회 1,581
14년 전 조회 1,532
14년 전 조회 2,351
14년 전 조회 2,488
14년 전 조회 2,358
14년 전 조회 1,509
14년 전 조회 2,065
14년 전 조회 2,116
14년 전 조회 2,208
14년 전 조회 3,989
14년 전 조회 1,534
14년 전 조회 2,335
14년 전 조회 1,257
14년 전 조회 1,396
14년 전 조회 1,259
14년 전 조회 1,677
14년 전 조회 2,130
14년 전 조회 1,671
14년 전 조회 1,534
14년 전 조회 1,203
14년 전 조회 2,180
14년 전 조회 1,749
14년 전 조회 1,281
14년 전 조회 2,703
14년 전 조회 1,791
14년 전 조회 1,734
14년 전 조회 1,248
14년 전 조회 2,135
14년 전 조회 3,101
14년 전 조회 1,502
14년 전 조회 952
14년 전 조회 2,484
14년 전 조회 2,246
14년 전 조회 1,190
14년 전 조회 1,763
14년 전 조회 1,940
14년 전 조회 1,797
14년 전 조회 1,140
14년 전 조회 1,131
14년 전 조회 1,431
14년 전 조회 1,758
14년 전 조회 1,605
14년 전 조회 1,298
14년 전 조회 1,712
14년 전 조회 1,543
14년 전 조회 1,850
14년 전 조회 1,300
14년 전 조회 1,542
14년 전 조회 1,320
14년 전 조회 1,679
14년 전 조회 1,154
14년 전 조회 2,560
14년 전 조회 1,762
14년 전 조회 3,343
14년 전 조회 1,734
14년 전 조회 1,493
14년 전 조회 1,557
14년 전 조회 1,541
14년 전 조회 996
14년 전 조회 1,253
14년 전 조회 1,332
14년 전 조회 2,784
15년 전 조회 1,424
15년 전 조회 3,788
15년 전 조회 1,242
15년 전 조회 1,072
15년 전 조회 1,154
15년 전 조회 2,144
15년 전 조회 1,750
15년 전 조회 1,571
15년 전 조회 1,623
15년 전 조회 1,548
15년 전 조회 1,651
15년 전 조회 1,311
15년 전 조회 917
15년 전 조회 1,417