굿

로컬 IP 가지고 오기

· 14년 전 · 1364
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,358
14년 전 조회 1,059
14년 전 조회 1,482
14년 전 조회 1,650
14년 전 조회 851
14년 전 조회 2,097
14년 전 조회 2,071
14년 전 조회 1,657
14년 전 조회 1,614
14년 전 조회 1,127
14년 전 조회 1,605
14년 전 조회 1,537
14년 전 조회 1,248
14년 전 조회 982
14년 전 조회 2,727
14년 전 조회 2,037
14년 전 조회 1,393
14년 전 조회 2,051
14년 전 조회 928
14년 전 조회 1,025
14년 전 조회 1,649
14년 전 조회 1,753
14년 전 조회 1,356
14년 전 조회 1,048
14년 전 조회 1,215
14년 전 조회 1,150
14년 전 조회 2,001
14년 전 조회 2,124
14년 전 조회 1,999
14년 전 조회 1,131
14년 전 조회 1,702
14년 전 조회 1,756
14년 전 조회 1,854
14년 전 조회 3,627
14년 전 조회 1,178
14년 전 조회 1,979
14년 전 조회 894
14년 전 조회 1,030
14년 전 조회 876
14년 전 조회 1,330
14년 전 조회 1,785
14년 전 조회 1,324
14년 전 조회 1,176
14년 전 조회 833
14년 전 조회 1,813
14년 전 조회 1,384
14년 전 조회 944
14년 전 조회 2,331
14년 전 조회 1,446
14년 전 조회 1,365
14년 전 조회 900
14년 전 조회 1,771
14년 전 조회 2,741
14년 전 조회 1,239
14년 전 조회 636
14년 전 조회 2,199
14년 전 조회 1,957
14년 전 조회 905
14년 전 조회 1,486
14년 전 조회 1,661
14년 전 조회 1,522
14년 전 조회 881
14년 전 조회 849
14년 전 조회 1,157
14년 전 조회 1,482
14년 전 조회 1,338
14년 전 조회 1,020
14년 전 조회 1,448
14년 전 조회 1,293
14년 전 조회 1,568
14년 전 조회 1,017
14년 전 조회 1,254
14년 전 조회 1,054
14년 전 조회 1,412
14년 전 조회 878
14년 전 조회 2,272
14년 전 조회 1,481
14년 전 조회 3,080
14년 전 조회 1,455
14년 전 조회 1,227
14년 전 조회 1,275
14년 전 조회 1,275
14년 전 조회 737
14년 전 조회 999
14년 전 조회 1,044
14년 전 조회 2,499
14년 전 조회 1,133
14년 전 조회 3,498
14년 전 조회 971
14년 전 조회 806
14년 전 조회 872
14년 전 조회 1,855
14년 전 조회 1,474
14년 전 조회 1,290
14년 전 조회 1,348
14년 전 조회 1,276
14년 전 조회 1,379
14년 전 조회 1,037
14년 전 조회 640
14년 전 조회 1,155
🐛 버그신고