굿

로컬 IP 가지고 오기

· 14년 전 · 1370
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,365
14년 전 조회 1,069
14년 전 조회 1,487
14년 전 조회 1,659
14년 전 조회 859
14년 전 조회 2,101
14년 전 조회 2,078
14년 전 조회 1,664
14년 전 조회 1,622
14년 전 조회 1,135
14년 전 조회 1,615
14년 전 조회 1,545
14년 전 조회 1,251
14년 전 조회 990
14년 전 조회 2,734
14년 전 조회 2,045
14년 전 조회 1,405
14년 전 조회 2,058
14년 전 조회 934
14년 전 조회 1,036
14년 전 조회 1,661
14년 전 조회 1,761
14년 전 조회 1,366
14년 전 조회 1,057
14년 전 조회 1,220
14년 전 조회 1,159
14년 전 조회 2,009
14년 전 조회 2,129
14년 전 조회 2,005
14년 전 조회 1,138
14년 전 조회 1,708
14년 전 조회 1,761
14년 전 조회 1,860
14년 전 조회 3,638
14년 전 조회 1,188
14년 전 조회 1,981
14년 전 조회 904
14년 전 조회 1,037
14년 전 조회 880
14년 전 조회 1,337
14년 전 조회 1,792
14년 전 조회 1,329
14년 전 조회 1,182
14년 전 조회 838
14년 전 조회 1,818
14년 전 조회 1,393
14년 전 조회 954
14년 전 조회 2,335
14년 전 조회 1,449
14년 전 조회 1,371
14년 전 조회 907
14년 전 조회 1,781
14년 전 조회 2,751
14년 전 조회 1,247
14년 전 조회 642
14년 전 조회 2,202
14년 전 조회 1,964
14년 전 조회 911
14년 전 조회 1,493
14년 전 조회 1,668
14년 전 조회 1,527
14년 전 조회 885
14년 전 조회 854
14년 전 조회 1,163
14년 전 조회 1,488
14년 전 조회 1,346
14년 전 조회 1,024
14년 전 조회 1,450
14년 전 조회 1,298
14년 전 조회 1,574
14년 전 조회 1,021
14년 전 조회 1,258
14년 전 조회 1,058
14년 전 조회 1,421
14년 전 조회 883
14년 전 조회 2,283
14년 전 조회 1,484
14년 전 조회 3,082
14년 전 조회 1,462
14년 전 조회 1,235
14년 전 조회 1,280
14년 전 조회 1,282
14년 전 조회 743
14년 전 조회 1,003
14년 전 조회 1,051
14년 전 조회 2,504
14년 전 조회 1,139
14년 전 조회 3,504
14년 전 조회 976
14년 전 조회 812
14년 전 조회 878
14년 전 조회 1,859
14년 전 조회 1,482
14년 전 조회 1,295
14년 전 조회 1,352
14년 전 조회 1,281
14년 전 조회 1,385
14년 전 조회 1,043
14년 전 조회 647
14년 전 조회 1,158