굿

로컬 IP 가지고 오기

· 14년 전 · 1433
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,429
14년 전 조회 1,129
14년 전 조회 1,554
14년 전 조회 1,728
14년 전 조회 932
14년 전 조회 2,172
14년 전 조회 2,144
14년 전 조회 1,726
14년 전 조회 1,689
14년 전 조회 1,200
14년 전 조회 1,689
14년 전 조회 1,610
14년 전 조회 1,321
14년 전 조회 1,057
14년 전 조회 2,798
14년 전 조회 2,112
14년 전 조회 1,466
14년 전 조회 2,126
14년 전 조회 996
14년 전 조회 1,094
14년 전 조회 1,727
14년 전 조회 1,826
14년 전 조회 1,422
14년 전 조회 1,118
14년 전 조회 1,302
14년 전 조회 1,222
14년 전 조회 2,068
14년 전 조회 2,196
14년 전 조회 2,075
14년 전 조회 1,201
14년 전 조회 1,770
14년 전 조회 1,827
14년 전 조회 1,927
14년 전 조회 3,706
14년 전 조회 1,249
14년 전 조회 2,045
14년 전 조회 971
14년 전 조회 1,099
14년 전 조회 954
14년 전 조회 1,406
14년 전 조회 1,860
14년 전 조회 1,394
14년 전 조회 1,246
14년 전 조회 911
14년 전 조회 1,879
14년 전 조회 1,458
14년 전 조회 1,009
14년 전 조회 2,404
14년 전 조회 1,507
14년 전 조회 1,434
14년 전 조회 968
14년 전 조회 1,844
14년 전 조회 2,813
14년 전 조회 1,281
14년 전 조회 703
14년 전 조회 2,256
14년 전 조회 2,030
14년 전 조회 979
14년 전 조회 1,553
14년 전 조회 1,731
14년 전 조회 1,595
14년 전 조회 953
14년 전 조회 910
14년 전 조회 1,240
14년 전 조회 1,551
14년 전 조회 1,415
14년 전 조회 1,088
14년 전 조회 1,508
14년 전 조회 1,365
14년 전 조회 1,637
14년 전 조회 1,092
14년 전 조회 1,323
14년 전 조회 1,123
14년 전 조회 1,480
14년 전 조회 951
14년 전 조회 2,357
14년 전 조회 1,544
14년 전 조회 3,147
14년 전 조회 1,530
14년 전 조회 1,299
14년 전 조회 1,342
14년 전 조회 1,341
14년 전 조회 815
14년 전 조회 1,063
14년 전 조회 1,115
14년 전 조회 2,578
14년 전 조회 1,200
14년 전 조회 3,579
14년 전 조회 1,035
14년 전 조회 868
14년 전 조회 939
14년 전 조회 1,922
14년 전 조회 1,546
14년 전 조회 1,358
14년 전 조회 1,414
14년 전 조회 1,344
14년 전 조회 1,453
14년 전 조회 1,106
14년 전 조회 707
14년 전 조회 1,224