굿

로컬 IP 가지고 오기

· 14년 전 · 1420
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,413
14년 전 조회 1,117
14년 전 조회 1,539
14년 전 조회 1,714
14년 전 조회 919
14년 전 조회 2,162
14년 전 조회 2,130
14년 전 조회 1,714
14년 전 조회 1,680
14년 전 조회 1,190
14년 전 조회 1,671
14년 전 조회 1,596
14년 전 조회 1,307
14년 전 조회 1,042
14년 전 조회 2,781
14년 전 조회 2,102
14년 전 조회 1,455
14년 전 조회 2,106
14년 전 조회 985
14년 전 조회 1,083
14년 전 조회 1,717
14년 전 조회 1,814
14년 전 조회 1,408
14년 전 조회 1,112
14년 전 조회 1,284
14년 전 조회 1,208
14년 전 조회 2,056
14년 전 조회 2,186
14년 전 조회 2,063
14년 전 조회 1,190
14년 전 조회 1,758
14년 전 조회 1,810
14년 전 조회 1,913
14년 전 조회 3,696
14년 전 조회 1,237
14년 전 조회 2,034
14년 전 조회 956
14년 전 조회 1,087
14년 전 조회 935
14년 전 조회 1,387
14년 전 조회 1,844
14년 전 조회 1,384
14년 전 조회 1,231
14년 전 조회 892
14년 전 조회 1,865
14년 전 조회 1,439
14년 전 조회 997
14년 전 조회 2,390
14년 전 조회 1,492
14년 전 조회 1,421
14년 전 조회 956
14년 전 조회 1,836
14년 전 조회 2,804
14년 전 조회 1,273
14년 전 조회 693
14년 전 조회 2,246
14년 전 조회 2,021
14년 전 조회 964
14년 전 조회 1,538
14년 전 조회 1,714
14년 전 조회 1,580
14년 전 조회 934
14년 전 조회 900
14년 전 조회 1,220
14년 전 조회 1,537
14년 전 조회 1,398
14년 전 조회 1,076
14년 전 조회 1,496
14년 전 조회 1,347
14년 전 조회 1,622
14년 전 조회 1,083
14년 전 조회 1,312
14년 전 조회 1,108
14년 전 조회 1,472
14년 전 조회 934
14년 전 조회 2,343
14년 전 조회 1,531
14년 전 조회 3,132
14년 전 조회 1,511
14년 전 조회 1,286
14년 전 조회 1,329
14년 전 조회 1,324
14년 전 조회 801
14년 전 조회 1,048
14년 전 조회 1,098
14년 전 조회 2,568
14년 전 조회 1,183
14년 전 조회 3,559
14년 전 조회 1,021
14년 전 조회 854
14년 전 조회 926
14년 전 조회 1,910
14년 전 조회 1,529
14년 전 조회 1,344
14년 전 조회 1,403
14년 전 조회 1,330
14년 전 조회 1,442
14년 전 조회 1,092
14년 전 조회 696
14년 전 조회 1,209