굿

로컬 IP 가지고 오기

· 14년 전 · 1383
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,369
14년 전 조회 1,082
14년 전 조회 1,497
14년 전 조회 1,669
14년 전 조회 877
14년 전 조회 2,115
14년 전 조회 2,091
14년 전 조회 1,675
14년 전 조회 1,635
14년 전 조회 1,142
14년 전 조회 1,623
14년 전 조회 1,557
14년 전 조회 1,263
14년 전 조회 996
14년 전 조회 2,742
14년 전 조회 2,056
14년 전 조회 1,417
14년 전 조회 2,071
14년 전 조회 943
14년 전 조회 1,050
14년 전 조회 1,673
14년 전 조회 1,773
14년 전 조회 1,373
14년 전 조회 1,065
14년 전 조회 1,235
14년 전 조회 1,167
14년 전 조회 2,016
14년 전 조회 2,140
14년 전 조회 2,020
14년 전 조회 1,145
14년 전 조회 1,723
14년 전 조회 1,771
14년 전 조회 1,875
14년 전 조회 3,648
14년 전 조회 1,198
14년 전 조회 1,991
14년 전 조회 909
14년 전 조회 1,056
14년 전 조회 898
14년 전 조회 1,345
14년 전 조회 1,810
14년 전 조회 1,334
14년 전 조회 1,192
14년 전 조회 848
14년 전 조회 1,823
14년 전 조회 1,404
14년 전 조회 961
14년 전 조회 2,347
14년 전 조회 1,455
14년 전 조회 1,384
14년 전 조회 926
14년 전 조회 1,793
14년 전 조회 2,763
14년 전 조회 1,248
14년 전 조회 652
14년 전 조회 2,215
14년 전 조회 1,975
14년 전 조회 919
14년 전 조회 1,498
14년 전 조회 1,680
14년 전 조회 1,534
14년 전 조회 894
14년 전 조회 868
14년 전 조회 1,176
14년 전 조회 1,503
14년 전 조회 1,351
14년 전 조회 1,037
14년 전 조회 1,457
14년 전 조회 1,304
14년 전 조회 1,587
14년 전 조회 1,033
14년 전 조회 1,265
14년 전 조회 1,067
14년 전 조회 1,428
14년 전 조회 889
14년 전 조회 2,299
14년 전 조회 1,492
14년 전 조회 3,092
14년 전 조회 1,479
14년 전 조회 1,249
14년 전 조회 1,288
14년 전 조회 1,286
14년 전 조회 756
14년 전 조회 1,012
14년 전 조회 1,064
14년 전 조회 2,515
14년 전 조회 1,148
14년 전 조회 3,518
14년 전 조회 980
14년 전 조회 816
14년 전 조회 886
14년 전 조회 1,871
14년 전 조회 1,490
14년 전 조회 1,306
14년 전 조회 1,360
14년 전 조회 1,287
14년 전 조회 1,397
14년 전 조회 1,056
14년 전 조회 653
14년 전 조회 1,166