굿

로컬 IP 가지고 오기

· 14년 전 · 1391
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,376
14년 전 조회 1,086
14년 전 조회 1,500
14년 전 조회 1,677
14년 전 조회 884
14년 전 조회 2,118
14년 전 조회 2,098
14년 전 조회 1,682
14년 전 조회 1,640
14년 전 조회 1,148
14년 전 조회 1,626
14년 전 조회 1,564
14년 전 조회 1,265
14년 전 조회 1,002
14년 전 조회 2,744
14년 전 조회 2,059
14년 전 조회 1,423
14년 전 조회 2,073
14년 전 조회 951
14년 전 조회 1,055
14년 전 조회 1,674
14년 전 조회 1,779
14년 전 조회 1,379
14년 전 조회 1,072
14년 전 조회 1,238
14년 전 조회 1,175
14년 전 조회 2,021
14년 전 조회 2,146
14년 전 조회 2,023
14년 전 조회 1,151
14년 전 조회 1,728
14년 전 조회 1,773
14년 전 조회 1,880
14년 전 조회 3,653
14년 전 조회 1,201
14년 전 조회 2,000
14년 전 조회 914
14년 전 조회 1,061
14년 전 조회 902
14년 전 조회 1,352
14년 전 조회 1,818
14년 전 조회 1,340
14년 전 조회 1,196
14년 전 조회 855
14년 전 조회 1,830
14년 전 조회 1,407
14년 전 조회 967
14년 전 조회 2,355
14년 전 조회 1,457
14년 전 조회 1,392
14년 전 조회 931
14년 전 조회 1,798
14년 전 조회 2,771
14년 전 조회 1,249
14년 전 조회 656
14년 전 조회 2,219
14년 전 조회 1,980
14년 전 조회 924
14년 전 조회 1,505
14년 전 조회 1,692
14년 전 조회 1,537
14년 전 조회 896
14년 전 조회 874
14년 전 조회 1,185
14년 전 조회 1,506
14년 전 조회 1,357
14년 전 조회 1,044
14년 전 조회 1,462
14년 전 조회 1,307
14년 전 조회 1,589
14년 전 조회 1,038
14년 전 조회 1,270
14년 전 조회 1,072
14년 전 조회 1,430
14년 전 조회 894
14년 전 조회 2,303
14년 전 조회 1,498
14년 전 조회 3,097
14년 전 조회 1,482
14년 전 조회 1,251
14년 전 조회 1,294
14년 전 조회 1,290
14년 전 조회 760
14년 전 조회 1,018
14년 전 조회 1,066
14년 전 조회 2,525
14년 전 조회 1,151
14년 전 조회 3,524
14년 전 조회 984
14년 전 조회 821
14년 전 조회 892
14년 전 조회 1,875
14년 전 조회 1,493
14년 전 조회 1,316
14년 전 조회 1,364
14년 전 조회 1,290
14년 전 조회 1,406
14년 전 조회 1,058
14년 전 조회 658
14년 전 조회 1,173