굿

로컬 IP 가지고 오기

· 14년 전 · 1513
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,481
14년 전 조회 1,203
14년 전 조회 1,656
14년 전 조회 1,783
14년 전 조회 1,004
14년 전 조회 2,245
14년 전 조회 2,210
14년 전 조회 1,790
14년 전 조회 1,744
14년 전 조회 1,255
14년 전 조회 1,757
14년 전 조회 1,687
14년 전 조회 1,391
14년 전 조회 1,114
14년 전 조회 2,852
14년 전 조회 2,170
14년 전 조회 1,537
14년 전 조회 2,188
14년 전 조회 1,071
14년 전 조회 1,173
14년 전 조회 1,810
14년 전 조회 1,877
14년 전 조회 1,501
14년 전 조회 1,184
14년 전 조회 1,361
14년 전 조회 1,296
14년 전 조회 2,133
14년 전 조회 2,251
14년 전 조회 2,131
14년 전 조회 1,280
14년 전 조회 1,840
14년 전 조회 1,882
14년 전 조회 1,978
14년 전 조회 3,763
14년 전 조회 1,308
14년 전 조회 2,108
14년 전 조회 1,025
14년 전 조회 1,151
14년 전 조회 1,004
14년 전 조회 1,461
14년 전 조회 1,916
14년 전 조회 1,455
14년 전 조회 1,316
14년 전 조회 982
14년 전 조회 1,943
14년 전 조회 1,518
14년 전 조회 1,070
14년 전 조회 2,468
14년 전 조회 1,578
14년 전 조회 1,514
14년 전 조회 1,038
14년 전 조회 1,918
14년 전 조회 2,877
14년 전 조회 1,347
14년 전 조회 785
14년 전 조회 2,323
14년 전 조회 2,089
14년 전 조회 1,038
14년 전 조회 1,608
14년 전 조회 1,791
14년 전 조회 1,651
14년 전 조회 1,013
14년 전 조회 974
14년 전 조회 1,289
14년 전 조회 1,601
14년 전 조회 1,469
14년 전 조회 1,162
14년 전 조회 1,572
14년 전 조회 1,415
14년 전 조회 1,714
14년 전 조회 1,172
14년 전 조회 1,393
14년 전 조회 1,179
14년 전 조회 1,538
14년 전 조회 1,005
14년 전 조회 2,423
14년 전 조회 1,604
14년 전 조회 3,202
14년 전 조회 1,585
14년 전 조회 1,362
14년 전 조회 1,406
14년 전 조회 1,401
14년 전 조회 863
14년 전 조회 1,110
14년 전 조회 1,180
14년 전 조회 2,634
14년 전 조회 1,282
14년 전 조회 3,643
14년 전 조회 1,096
14년 전 조회 936
14년 전 조회 1,008
14년 전 조회 2,003
14년 전 조회 1,610
14년 전 조회 1,422
14년 전 조회 1,471
14년 전 조회 1,403
14년 전 조회 1,511
14년 전 조회 1,167
14년 전 조회 769
14년 전 조회 1,283