굿

로컬 IP 가지고 오기

· 14년 전 · 1366
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,362
14년 전 조회 1,064
14년 전 조회 1,487
14년 전 조회 1,655
14년 전 조회 854
14년 전 조회 2,099
14년 전 조회 2,076
14년 전 조회 1,660
14년 전 조회 1,617
14년 전 조회 1,133
14년 전 조회 1,611
14년 전 조회 1,545
14년 전 조회 1,251
14년 전 조회 988
14년 전 조회 2,732
14년 전 조회 2,044
14년 전 조회 1,400
14년 전 조회 2,054
14년 전 조회 933
14년 전 조회 1,033
14년 전 조회 1,655
14년 전 조회 1,756
14년 전 조회 1,362
14년 전 조회 1,052
14년 전 조회 1,218
14년 전 조회 1,157
14년 전 조회 2,004
14년 전 조회 2,127
14년 전 조회 2,005
14년 전 조회 1,134
14년 전 조회 1,707
14년 전 조회 1,758
14년 전 조회 1,860
14년 전 조회 3,633
14년 전 조회 1,181
14년 전 조회 1,980
14년 전 조회 899
14년 전 조회 1,036
14년 전 조회 878
14년 전 조회 1,334
14년 전 조회 1,788
14년 전 조회 1,327
14년 전 조회 1,181
14년 전 조회 837
14년 전 조회 1,816
14년 전 조회 1,389
14년 전 조회 951
14년 전 조회 2,335
14년 전 조회 1,448
14년 전 조회 1,367
14년 전 조회 903
14년 전 조회 1,777
14년 전 조회 2,748
14년 전 조회 1,246
14년 전 조회 641
14년 전 조회 2,200
14년 전 조회 1,962
14년 전 조회 910
14년 전 조회 1,492
14년 전 조회 1,667
14년 전 조회 1,525
14년 전 조회 884
14년 전 조회 851
14년 전 조회 1,160
14년 전 조회 1,487
14년 전 조회 1,344
14년 전 조회 1,023
14년 전 조회 1,450
14년 전 조회 1,297
14년 전 조회 1,570
14년 전 조회 1,019
14년 전 조회 1,258
14년 전 조회 1,057
14년 전 조회 1,418
14년 전 조회 883
14년 전 조회 2,278
14년 전 조회 1,483
14년 전 조회 3,080
14년 전 조회 1,460
14년 전 조회 1,229
14년 전 조회 1,278
14년 전 조회 1,280
14년 전 조회 742
14년 전 조회 1,000
14년 전 조회 1,047
14년 전 조회 2,501
14년 전 조회 1,138
14년 전 조회 3,502
14년 전 조회 973
14년 전 조회 812
14년 전 조회 875
14년 전 조회 1,859
14년 전 조회 1,480
14년 전 조회 1,294
14년 전 조회 1,351
14년 전 조회 1,279
14년 전 조회 1,382
14년 전 조회 1,040
14년 전 조회 643
14년 전 조회 1,157
🐛 버그신고