굿

로컬 IP 가지고 오기

· 14년 전 · 1657
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,661
14년 전 조회 1,365
14년 전 조회 1,866
14년 전 조회 1,960
14년 전 조회 1,174
14년 전 조회 2,416
14년 전 조회 2,392
14년 전 조회 1,975
14년 전 조회 1,920
14년 전 조회 1,447
14년 전 조회 1,928
14년 전 조회 1,849
14년 전 조회 1,553
14년 전 조회 1,262
14년 전 조회 3,016
14년 전 조회 2,330
14년 전 조회 1,690
14년 전 조회 2,347
14년 전 조회 1,222
14년 전 조회 1,330
14년 전 조회 1,962
14년 전 조회 2,042
14년 전 조회 1,652
14년 전 조회 1,343
14년 전 조회 1,509
14년 전 조회 1,454
14년 전 조회 2,284
14년 전 조회 2,413
14년 전 조회 2,284
14년 전 조회 1,446
14년 전 조회 2,001
14년 전 조회 2,046
14년 전 조회 2,137
14년 전 조회 3,916
14년 전 조회 1,468
14년 전 조회 2,268
14년 전 조회 1,182
14년 전 조회 1,311
14년 전 조회 1,174
14년 전 조회 1,610
14년 전 조회 2,059
14년 전 조회 1,605
14년 전 조회 1,456
14년 전 조회 1,138
14년 전 조회 2,098
14년 전 조회 1,668
14년 전 조회 1,210
14년 전 조회 2,623
14년 전 조회 1,724
14년 전 조회 1,658
14년 전 조회 1,177
14년 전 조회 2,061
14년 전 조회 3,031
14년 전 조회 1,450
14년 전 조회 900
14년 전 조회 2,433
14년 전 조회 2,186
14년 전 조회 1,149
14년 전 조회 1,711
14년 전 조회 1,892
14년 전 조회 1,754
14년 전 조회 1,093
14년 전 조회 1,077
14년 전 조회 1,389
14년 전 조회 1,706
14년 전 조회 1,567
14년 전 조회 1,255
14년 전 조회 1,671
14년 전 조회 1,508
14년 전 조회 1,803
14년 전 조회 1,256
14년 전 조회 1,491
14년 전 조회 1,278
14년 전 조회 1,641
14년 전 조회 1,110
14년 전 조회 2,517
14년 전 조회 1,713
14년 전 조회 3,295
14년 전 조회 1,686
14년 전 조회 1,452
14년 전 조회 1,514
14년 전 조회 1,496
14년 전 조회 947
14년 전 조회 1,212
14년 전 조회 1,283
14년 전 조회 2,738
14년 전 조회 1,381
14년 전 조회 3,740
14년 전 조회 1,198
14년 전 조회 1,029
14년 전 조회 1,110
14년 전 조회 2,101
14년 전 조회 1,708
14년 전 조회 1,511
14년 전 조회 1,570
14년 전 조회 1,499
14년 전 조회 1,606
14년 전 조회 1,263
14년 전 조회 865
14년 전 조회 1,382