굿

로컬 IP 가지고 오기

· 14년 전 · 1662
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,665
14년 전 조회 1,372
14년 전 조회 1,870
14년 전 조회 1,962
14년 전 조회 1,177
14년 전 조회 2,421
14년 전 조회 2,395
14년 전 조회 1,978
14년 전 조회 1,924
14년 전 조회 1,450
14년 전 조회 1,932
14년 전 조회 1,852
14년 전 조회 1,559
14년 전 조회 1,265
14년 전 조회 3,020
14년 전 조회 2,333
14년 전 조회 1,694
14년 전 조회 2,349
14년 전 조회 1,223
14년 전 조회 1,333
14년 전 조회 1,971
14년 전 조회 2,044
14년 전 조회 1,656
14년 전 조회 1,344
14년 전 조회 1,511
14년 전 조회 1,455
14년 전 조회 2,289
14년 전 조회 2,418
14년 전 조회 2,290
14년 전 조회 1,451
14년 전 조회 2,003
14년 전 조회 2,048
14년 전 조회 2,141
14년 전 조회 3,918
14년 전 조회 1,472
14년 전 조회 2,274
14년 전 조회 1,184
14년 전 조회 1,313
14년 전 조회 1,176
14년 전 조회 1,615
14년 전 조회 2,062
14년 전 조회 1,610
14년 전 조회 1,458
14년 전 조회 1,144
14년 전 조회 2,102
14년 전 조회 1,669
14년 전 조회 1,212
14년 전 조회 2,626
14년 전 조회 1,728
14년 전 조회 1,663
14년 전 조회 1,182
14년 전 조회 2,063
14년 전 조회 3,034
14년 전 조회 1,453
14년 전 조회 902
14년 전 조회 2,438
14년 전 조회 2,190
14년 전 조회 1,152
14년 전 조회 1,712
14년 전 조회 1,893
14년 전 조회 1,757
14년 전 조회 1,099
14년 전 조회 1,083
14년 전 조회 1,391
14년 전 조회 1,711
14년 전 조회 1,571
14년 전 조회 1,257
14년 전 조회 1,674
14년 전 조회 1,509
14년 전 조회 1,804
14년 전 조회 1,261
14년 전 조회 1,495
14년 전 조회 1,282
14년 전 조회 1,645
14년 전 조회 1,114
14년 전 조회 2,523
14년 전 조회 1,716
14년 전 조회 3,298
14년 전 조회 1,691
14년 전 조회 1,456
14년 전 조회 1,519
14년 전 조회 1,499
14년 전 조회 952
14년 전 조회 1,213
14년 전 조회 1,283
14년 전 조회 2,746
14년 전 조회 1,386
14년 전 조회 3,743
14년 전 조회 1,201
14년 전 조회 1,030
14년 전 조회 1,113
14년 전 조회 2,108
14년 전 조회 1,712
14년 전 조회 1,517
14년 전 조회 1,577
14년 전 조회 1,506
14년 전 조회 1,608
14년 전 조회 1,264
14년 전 조회 868
14년 전 조회 1,385