굿

로컬 IP 가지고 오기

· 14년 전 · 1361
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,355
14년 전 조회 1,056
14년 전 조회 1,480
14년 전 조회 1,648
14년 전 조회 847
14년 전 조회 2,095
14년 전 조회 2,070
14년 전 조회 1,656
14년 전 조회 1,608
14년 전 조회 1,127
14년 전 조회 1,605
14년 전 조회 1,534
14년 전 조회 1,244
14년 전 조회 978
14년 전 조회 2,725
14년 전 조회 2,035
14년 전 조회 1,391
14년 전 조회 2,047
14년 전 조회 926
14년 전 조회 1,023
14년 전 조회 1,648
14년 전 조회 1,752
14년 전 조회 1,355
14년 전 조회 1,047
14년 전 조회 1,213
14년 전 조회 1,149
14년 전 조회 1,998
14년 전 조회 2,122
14년 전 조회 1,997
14년 전 조회 1,131
14년 전 조회 1,700
14년 전 조회 1,756
14년 전 조회 1,851
14년 전 조회 3,623
14년 전 조회 1,176
14년 전 조회 1,976
14년 전 조회 892
14년 전 조회 1,027
14년 전 조회 876
14년 전 조회 1,327
14년 전 조회 1,784
14년 전 조회 1,322
14년 전 조회 1,174
14년 전 조회 832
14년 전 조회 1,811
14년 전 조회 1,382
14년 전 조회 944
14년 전 조회 2,328
14년 전 조회 1,443
14년 전 조회 1,362
14년 전 조회 897
14년 전 조회 1,770
14년 전 조회 2,741
14년 전 조회 1,235
14년 전 조회 633
14년 전 조회 2,196
14년 전 조회 1,953
14년 전 조회 902
14년 전 조회 1,484
14년 전 조회 1,658
14년 전 조회 1,519
14년 전 조회 880
14년 전 조회 847
14년 전 조회 1,155
14년 전 조회 1,481
14년 전 조회 1,333
14년 전 조회 1,018
14년 전 조회 1,446
14년 전 조회 1,291
14년 전 조회 1,567
14년 전 조회 1,015
14년 전 조회 1,253
14년 전 조회 1,050
14년 전 조회 1,410
14년 전 조회 874
14년 전 조회 2,266
14년 전 조회 1,480
14년 전 조회 3,079
14년 전 조회 1,452
14년 전 조회 1,223
14년 전 조회 1,272
14년 전 조회 1,274
14년 전 조회 737
14년 전 조회 998
14년 전 조회 1,040
14년 전 조회 2,497
14년 전 조회 1,132
14년 전 조회 3,498
14년 전 조회 970
14년 전 조회 802
14년 전 조회 869
14년 전 조회 1,854
14년 전 조회 1,473
14년 전 조회 1,286
14년 전 조회 1,346
14년 전 조회 1,274
14년 전 조회 1,378
14년 전 조회 1,035
14년 전 조회 639
14년 전 조회 1,152
🐛 버그신고