굿

로컬 IP 가지고 오기

· 14년 전 · 1666
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,667
14년 전 조회 1,373
14년 전 조회 1,873
14년 전 조회 1,967
14년 전 조회 1,180
14년 전 조회 2,422
14년 전 조회 2,399
14년 전 조회 1,981
14년 전 조회 1,926
14년 전 조회 1,454
14년 전 조회 1,936
14년 전 조회 1,857
14년 전 조회 1,562
14년 전 조회 1,269
14년 전 조회 3,021
14년 전 조회 2,337
14년 전 조회 1,696
14년 전 조회 2,355
14년 전 조회 1,226
14년 전 조회 1,338
14년 전 조회 1,973
14년 전 조회 2,047
14년 전 조회 1,660
14년 전 조회 1,348
14년 전 조회 1,515
14년 전 조회 1,460
14년 전 조회 2,292
14년 전 조회 2,422
14년 전 조회 2,295
14년 전 조회 1,452
14년 전 조회 2,005
14년 전 조회 2,053
14년 전 조회 2,145
14년 전 조회 3,923
14년 전 조회 1,474
14년 전 조회 2,276
14년 전 조회 1,190
14년 전 조회 1,314
14년 전 조회 1,179
14년 전 조회 1,616
14년 전 조회 2,066
14년 전 조회 1,615
14년 전 조회 1,462
14년 전 조회 1,147
14년 전 조회 2,106
14년 전 조회 1,672
14년 전 조회 1,216
14년 전 조회 2,629
14년 전 조회 1,730
14년 전 조회 1,667
14년 전 조회 1,183
14년 전 조회 2,065
14년 전 조회 3,034
14년 전 조회 1,458
14년 전 조회 903
14년 전 조회 2,442
14년 전 조회 2,193
14년 전 조회 1,153
14년 전 조회 1,715
14년 전 조회 1,898
14년 전 조회 1,760
14년 전 조회 1,099
14년 전 조회 1,084
14년 전 조회 1,392
14년 전 조회 1,714
14년 전 조회 1,574
14년 전 조회 1,260
14년 전 조회 1,676
14년 전 조회 1,510
14년 전 조회 1,806
14년 전 조회 1,262
14년 전 조회 1,497
14년 전 조회 1,284
14년 전 조회 1,646
14년 전 조회 1,114
14년 전 조회 2,524
14년 전 조회 1,718
14년 전 조회 3,299
14년 전 조회 1,692
14년 전 조회 1,458
14년 전 조회 1,520
14년 전 조회 1,501
14년 전 조회 955
14년 전 조회 1,218
14년 전 조회 1,284
14년 전 조회 2,746
14년 전 조회 1,389
14년 전 조회 3,747
14년 전 조회 1,203
14년 전 조회 1,035
14년 전 조회 1,116
14년 전 조회 2,108
14년 전 조회 1,715
14년 전 조회 1,519
14년 전 조회 1,581
14년 전 조회 1,507
14년 전 조회 1,609
14년 전 조회 1,265
14년 전 조회 871
14년 전 조회 1,387