굿

로컬 IP 가지고 오기

· 14년 전 · 1358
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,348
14년 전 조회 1,051
14년 전 조회 1,478
14년 전 조회 1,641
14년 전 조회 839
14년 전 조회 2,089
14년 전 조회 2,066
14년 전 조회 1,651
14년 전 조회 1,605
14년 전 조회 1,119
14년 전 조회 1,596
14년 전 조회 1,529
14년 전 조회 1,239
14년 전 조회 971
14년 전 조회 2,719
14년 전 조회 2,030
14년 전 조회 1,383
14년 전 조회 2,042
14년 전 조회 920
14년 전 조회 1,019
14년 전 조회 1,643
14년 전 조회 1,748
14년 전 조회 1,350
14년 전 조회 1,040
14년 전 조회 1,208
14년 전 조회 1,143
14년 전 조회 1,991
14년 전 조회 2,116
14년 전 조회 1,989
14년 전 조회 1,122
14년 전 조회 1,694
14년 전 조회 1,750
14년 전 조회 1,845
14년 전 조회 3,616
14년 전 조회 1,170
14년 전 조회 1,970
14년 전 조회 887
14년 전 조회 1,022
14년 전 조회 867
14년 전 조회 1,322
14년 전 조회 1,777
14년 전 조회 1,319
14년 전 조회 1,166
14년 전 조회 827
14년 전 조회 1,806
14년 전 조회 1,375
14년 전 조회 937
14년 전 조회 2,321
14년 전 조회 1,436
14년 전 조회 1,359
14년 전 조회 893
14년 전 조회 1,764
14년 전 조회 2,735
14년 전 조회 1,229
14년 전 조회 627
14년 전 조회 2,188
14년 전 조회 1,949
14년 전 조회 896
14년 전 조회 1,478
14년 전 조회 1,655
14년 전 조회 1,513
14년 전 조회 873
14년 전 조회 840
14년 전 조회 1,149
14년 전 조회 1,473
14년 전 조회 1,329
14년 전 조회 1,013
14년 전 조회 1,441
14년 전 조회 1,280
14년 전 조회 1,557
14년 전 조회 1,008
14년 전 조회 1,245
14년 전 조회 1,044
14년 전 조회 1,403
14년 전 조회 867
14년 전 조회 2,265
14년 전 조회 1,473
14년 전 조회 3,073
14년 전 조회 1,446
14년 전 조회 1,220
14년 전 조회 1,264
14년 전 조회 1,267
14년 전 조회 735
14년 전 조회 991
14년 전 조회 1,031
14년 전 조회 2,490
14년 전 조회 1,127
14년 전 조회 3,489
14년 전 조회 961
14년 전 조회 794
14년 전 조회 860
14년 전 조회 1,845
14년 전 조회 1,466
14년 전 조회 1,277
14년 전 조회 1,340
14년 전 조회 1,267
14년 전 조회 1,371
14년 전 조회 1,030
14년 전 조회 632
14년 전 조회 1,145
🐛 버그신고