굿

로컬 IP 가지고 오기

· 14년 전 · 1401
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,388
14년 전 조회 1,096
14년 전 조회 1,512
14년 전 조회 1,693
14년 전 조회 899
14년 전 조회 2,134
14년 전 조회 2,109
14년 전 조회 1,693
14년 전 조회 1,655
14년 전 조회 1,162
14년 전 조회 1,642
14년 전 조회 1,577
14년 전 조회 1,283
14년 전 조회 1,012
14년 전 조회 2,759
14년 전 조회 2,071
14년 전 조회 1,437
14년 전 조회 2,082
14년 전 조회 964
14년 전 조회 1,065
14년 전 조회 1,688
14년 전 조회 1,799
14년 전 조회 1,392
14년 전 조회 1,083
14년 전 조회 1,253
14년 전 조회 1,182
14년 전 조회 2,033
14년 전 조회 2,159
14년 전 조회 2,035
14년 전 조회 1,167
14년 전 조회 1,740
14년 전 조회 1,793
14년 전 조회 1,896
14년 전 조회 3,671
14년 전 조회 1,217
14년 전 조회 2,017
14년 전 조회 928
14년 전 조회 1,072
14년 전 조회 914
14년 전 조회 1,362
14년 전 조회 1,829
14년 전 조회 1,355
14년 전 조회 1,211
14년 전 조회 870
14년 전 조회 1,842
14년 전 조회 1,424
14년 전 조회 977
14년 전 조회 2,366
14년 전 조회 1,475
14년 전 조회 1,402
14년 전 조회 940
14년 전 조회 1,809
14년 전 조회 2,785
14년 전 조회 1,255
14년 전 조회 664
14년 전 조회 2,229
14년 전 조회 1,996
14년 전 조회 936
14년 전 조회 1,515
14년 전 조회 1,703
14년 전 조회 1,550
14년 전 조회 909
14년 전 조회 881
14년 전 조회 1,195
14년 전 조회 1,515
14년 전 조회 1,371
14년 전 조회 1,053
14년 전 조회 1,476
14년 전 조회 1,321
14년 전 조회 1,600
14년 전 조회 1,053
14년 전 조회 1,283
14년 전 조회 1,086
14년 전 조회 1,449
14년 전 조회 907
14년 전 조회 2,317
14년 전 조회 1,511
14년 전 조회 3,109
14년 전 조회 1,496
14년 전 조회 1,265
14년 전 조회 1,305
14년 전 조회 1,300
14년 전 조회 776
14년 전 조회 1,026
14년 전 조회 1,082
14년 전 조회 2,539
14년 전 조회 1,165
14년 전 조회 3,537
14년 전 조회 1,002
14년 전 조회 830
14년 전 조회 904
14년 전 조회 1,886
14년 전 조회 1,507
14년 전 조회 1,325
14년 전 조회 1,377
14년 전 조회 1,306
14년 전 조회 1,416
14년 전 조회 1,070
14년 전 조회 670
14년 전 조회 1,184