굿

로컬 IP 가지고 오기

· 14년 전 · 1653
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,647
14년 전 조회 1,350
14년 전 조회 1,854
14년 전 조회 1,948
14년 전 조회 1,161
14년 전 조회 2,400
14년 전 조회 2,374
14년 전 조회 1,962
14년 전 조회 1,905
14년 전 조회 1,434
14년 전 조회 1,909
14년 전 조회 1,837
14년 전 조회 1,539
14년 전 조회 1,249
14년 전 조회 3,002
14년 전 조회 2,314
14년 전 조회 1,672
14년 전 조회 2,333
14년 전 조회 1,205
14년 전 조회 1,315
14년 전 조회 1,950
14년 전 조회 2,026
14년 전 조회 1,638
14년 전 조회 1,333
14년 전 조회 1,497
14년 전 조회 1,439
14년 전 조회 2,269
14년 전 조회 2,400
14년 전 조회 2,275
14년 전 조회 1,432
14년 전 조회 1,984
14년 전 조회 2,035
14년 전 조회 2,122
14년 전 조회 3,898
14년 전 조회 1,447
14년 전 조회 2,253
14년 전 조회 1,172
14년 전 조회 1,303
14년 전 조회 1,157
14년 전 조회 1,595
14년 전 조회 2,044
14년 전 조회 1,594
14년 전 조회 1,445
14년 전 조회 1,124
14년 전 조회 2,086
14년 전 조회 1,654
14년 전 조회 1,198
14년 전 조회 2,608
14년 전 조회 1,708
14년 전 조회 1,654
14년 전 조회 1,165
14년 전 조회 2,046
14년 전 조회 3,016
14년 전 조회 1,437
14년 전 조회 883
14년 전 조회 2,418
14년 전 조회 2,170
14년 전 조회 1,134
14년 전 조회 1,696
14년 전 조회 1,880
14년 전 조회 1,740
14년 전 조회 1,079
14년 전 조회 1,063
14년 전 조회 1,376
14년 전 조회 1,693
14년 전 조회 1,549
14년 전 조회 1,241
14년 전 조회 1,655
14년 전 조회 1,495
14년 전 조회 1,787
14년 전 조회 1,246
14년 전 조회 1,482
14년 전 조회 1,263
14년 전 조회 1,626
14년 전 조회 1,093
14년 전 조회 2,504
14년 전 조회 1,700
14년 전 조회 3,282
14년 전 조회 1,674
14년 전 조회 1,442
14년 전 조회 1,496
14년 전 조회 1,481
14년 전 조회 939
14년 전 조회 1,194
14년 전 조회 1,268
14년 전 조회 2,722
14년 전 조회 1,367
14년 전 조회 3,730
14년 전 조회 1,182
14년 전 조회 1,017
14년 전 조회 1,091
14년 전 조회 2,089
14년 전 조회 1,690
14년 전 조회 1,500
14년 전 조회 1,556
14년 전 조회 1,484
14년 전 조회 1,591
14년 전 조회 1,251
14년 전 조회 852
14년 전 조회 1,363