굿

로컬 IP 가지고 오기

· 14년 전 · 1360
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,352
14년 전 조회 1,054
14년 전 조회 1,479
14년 전 조회 1,646
14년 전 조회 843
14년 전 조회 2,092
14년 전 조회 2,068
14년 전 조회 1,655
14년 전 조회 1,607
14년 전 조회 1,123
14년 전 조회 1,602
14년 전 조회 1,531
14년 전 조회 1,243
14년 전 조회 976
14년 전 조회 2,723
14년 전 조회 2,033
14년 전 조회 1,387
14년 전 조회 2,046
14년 전 조회 922
14년 전 조회 1,020
14년 전 조회 1,647
14년 전 조회 1,751
14년 전 조회 1,353
14년 전 조회 1,042
14년 전 조회 1,212
14년 전 조회 1,148
14년 전 조회 1,995
14년 전 조회 2,122
14년 전 조회 1,994
14년 전 조회 1,127
14년 전 조회 1,697
14년 전 조회 1,754
14년 전 조회 1,849
14년 전 조회 3,623
14년 전 조회 1,174
14년 전 조회 1,975
14년 전 조회 890
14년 전 조회 1,023
14년 전 조회 874
14년 전 조회 1,326
14년 전 조회 1,783
14년 전 조회 1,321
14년 전 조회 1,171
14년 전 조회 832
14년 전 조회 1,809
14년 전 조회 1,380
14년 전 조회 940
14년 전 조회 2,327
14년 전 조회 1,441
14년 전 조회 1,361
14년 전 조회 896
14년 전 조회 1,766
14년 전 조회 2,737
14년 전 조회 1,233
14년 전 조회 631
14년 전 조회 2,191
14년 전 조회 1,951
14년 전 조회 899
14년 전 조회 1,482
14년 전 조회 1,658
14년 전 조회 1,517
14년 전 조회 878
14년 전 조회 847
14년 전 조회 1,154
14년 전 조회 1,478
14년 전 조회 1,333
14년 전 조회 1,016
14년 전 조회 1,445
14년 전 조회 1,290
14년 전 조회 1,564
14년 전 조회 1,012
14년 전 조회 1,250
14년 전 조회 1,050
14년 전 조회 1,406
14년 전 조회 873
14년 전 조회 2,266
14년 전 조회 1,478
14년 전 조회 3,077
14년 전 조회 1,451
14년 전 조회 1,223
14년 전 조회 1,270
14년 전 조회 1,272
14년 전 조회 737
14년 전 조회 996
14년 전 조회 1,037
14년 전 조회 2,496
14년 전 조회 1,132
14년 전 조회 3,493
14년 전 조회 966
14년 전 조회 800
14년 전 조회 867
14년 전 조회 1,850
14년 전 조회 1,470
14년 전 조회 1,283
14년 전 조회 1,344
14년 전 조회 1,273
14년 전 조회 1,377
14년 전 조회 1,033
14년 전 조회 638
14년 전 조회 1,149
🐛 버그신고