굿

로컬 IP 가지고 오기

· 14년 전 · 1489
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,471
14년 전 조회 1,182
14년 전 조회 1,613
14년 전 조회 1,775
14년 전 조회 981
14년 전 조회 2,224
14년 전 조회 2,196
14년 전 조회 1,769
14년 전 조회 1,736
14년 전 조회 1,247
14년 전 조회 1,730
14년 전 조회 1,664
14년 전 조회 1,371
14년 전 조회 1,102
14년 전 조회 2,838
14년 전 조회 2,155
14년 전 조회 1,510
14년 전 조회 2,166
14년 전 조회 1,051
14년 전 조회 1,150
14년 전 조회 1,780
14년 전 조회 1,864
14년 전 조회 1,483
14년 전 조회 1,168
14년 전 조회 1,343
14년 전 조회 1,275
14년 전 조회 2,119
14년 전 조회 2,238
14년 전 조회 2,125
14년 전 조회 1,260
14년 전 조회 1,830
14년 전 조회 1,873
14년 전 조회 1,966
14년 전 조회 3,749
14년 전 조회 1,293
14년 전 조회 2,090
14년 전 조회 1,010
14년 전 조회 1,138
14년 전 조회 996
14년 전 조회 1,449
14년 전 조회 1,899
14년 전 조회 1,438
14년 전 조회 1,301
14년 전 조회 965
14년 전 조회 1,934
14년 전 조회 1,509
14년 전 조회 1,058
14년 전 조회 2,448
14년 전 조회 1,561
14년 전 조회 1,490
14년 전 조회 1,025
14년 전 조회 1,897
14년 전 조회 2,864
14년 전 조회 1,341
14년 전 조회 762
14년 전 조회 2,317
14년 전 조회 2,084
14년 전 조회 1,022
14년 전 조회 1,596
14년 전 조회 1,778
14년 전 조회 1,647
14년 전 조회 1,003
14년 전 조회 963
14년 전 조회 1,277
14년 전 조회 1,593
14년 전 조회 1,453
14년 전 조회 1,143
14년 전 조회 1,564
14년 전 조회 1,402
14년 전 조회 1,690
14년 전 조회 1,148
14년 전 조회 1,376
14년 전 조회 1,171
14년 전 조회 1,528
14년 전 조회 990
14년 전 조회 2,401
14년 전 조회 1,593
14년 전 조회 3,182
14년 전 조회 1,577
14년 전 조회 1,353
14년 전 조회 1,398
14년 전 조회 1,389
14년 전 조회 857
14년 전 조회 1,100
14년 전 조회 1,168
14년 전 조회 2,624
14년 전 조회 1,253
14년 전 조회 3,625
14년 전 조회 1,090
14년 전 조회 923
14년 전 조회 998
14년 전 조회 1,983
14년 전 조회 1,595
14년 전 조회 1,411
14년 전 조회 1,460
14년 전 조회 1,393
14년 전 조회 1,503
14년 전 조회 1,162
14년 전 조회 762
14년 전 조회 1,275