Navigacija
Lista poslednjih: 16, 32, 64, 128 poruka.

IP adresa u Visual basicu

[es] :: Visual Basic 6 :: IP adresa u Visual basicu

Strane: 1 2

[ Pregleda: 5630 | Odgovora: 36 ] > FB > Twit

Postavi temu Odgovori

Autor

Pretraga teme: Traži
Markiranje Štampanje RSS

dava
Banja Luka

Član broj: 27208
Poruke: 893



+384 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 10:57 - pre 195 meseci
Evo recimo sa ovim kodom se mogu dobiti sve informacije koje se mogu izvuci iz cmd prompta:

U modul:
Code:

Option Explicit

Private Declare Function CreatePipe Lib "kernel32" (phReadPipe As Long, phWritePipe As Long, lpPipeAttributes As _
SECURITY_ATTRIBUTES, ByVal nSize As Long) As Long
Private Declare Sub GetStartupInfo Lib "kernel32" Alias "GetStartupInfoA" (lpStartupInfo As STARTUPINFO)
Private Declare Function CreateProcess Lib "kernel32" Alias "CreateProcessA" (ByVal lpApplicationName As String, _
ByVal lpCommandLine As String, lpProcessAttributes As Any, lpThreadAttributes As Any, ByVal bInheritHandles As Long, _
ByVal dwCreationFlags As Long, lpEnvironment As Any, ByVal lpCurrentDriectory As String, lpStartupInfo As STARTUPINFO, _
lpProcessInformation As PROCESS_INFORMATION) As Long
Private Declare Function SetWindowText Lib "user32" Alias "SetWindowTextA" (ByVal hwnd As Long, ByVal lpString As String) As Long
Private Declare Function ReadFile Lib "kernel32" (ByVal hFile As Long, lpBuffer As Any, ByVal nNumberOfBytesToRead As Long, _
lpNumberOfBytesRead As Long, lpOverlapped As Any) As Long
Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam _
As Long, lParam As Any) As Long
Private Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long

Private Type SECURITY_ATTRIBUTES
  nLength As Long
  lpSecurityDescriptor As Long
  bInheritHandle As Long
End Type

Private Type PROCESS_INFORMATION
  hProcess As Long
  hThread As Long
  dwProcessId As Long
  dwThreadId As Long
End Type

Private Type STARTUPINFO
  cb As Long
  lpReserved As Long
  lpDesktop As Long
  lpTitle As Long
  dwX As Long
  dwY As Long
  dwXSize As Long
  dwYSize As Long
  dwXCountChars As Long
  dwYCountChars As Long
  dwFillAttribute As Long
  dwFlags As Long
  wShowWindow As Integer
  cbReserved2 As Integer
  lpReserved2 As Byte
  hStdInput As Long
  hStdOutput As Long
  hStdError As Long
End Type

Private Type OVERLAPPED
    ternal As Long
    ternalHigh As Long
    offset As Long
    OffsetHigh As Long
    hEvent As Long
End Type

Private Const STARTF_USESHOWWINDOW = &H1
Private Const STARTF_USESTDHANDLES = &H100
Private Const SW_HIDE = 0
Private Const EM_SETSEL = &HB1
Private Const EM_REPLACESEL = &HC2

Public Sub Redirect(cmdLine As String, objTarget As Object)
  Dim i%, t$
  Dim pa As SECURITY_ATTRIBUTES
  Dim pra As SECURITY_ATTRIBUTES
  Dim tra As SECURITY_ATTRIBUTES
  Dim pi As PROCESS_INFORMATION
  Dim sui As STARTUPINFO
  Dim hRead As Long
  Dim hWrite As Long
  Dim bRead As Long
  Dim lpBuffer(1024) As Byte
  pa.nLength = Len(pa)
  pa.lpSecurityDescriptor = 0
  pa.bInheritHandle = True
  
  pra.nLength = Len(pra)
  tra.nLength = Len(tra)

  If CreatePipe(hRead, hWrite, pa, 0) <> 0 Then
    sui.cb = Len(sui)
    GetStartupInfo sui
    sui.hStdOutput = hWrite
    sui.hStdError = hWrite
    sui.dwFlags = STARTF_USESHOWWINDOW Or STARTF_USESTDHANDLES
    sui.wShowWindow = SW_HIDE
    If CreateProcess(vbNullString, cmdLine, pra, tra, True, 0, Null, vbNullString, sui, pi) <> 0 Then
      SetWindowText objTarget.hwnd, ""
      Do
        Erase lpBuffer()
        If ReadFile(hRead, lpBuffer(0), 1023, bRead, ByVal 0&) Then
          SendMessage objTarget.hwnd, EM_SETSEL, -1, 0
          SendMessage objTarget.hwnd, EM_REPLACESEL, False, lpBuffer(0)
          DoEvents
        Else
          CloseHandle pi.hThread
          CloseHandle pi.hProcess
          Exit Do
        End If
        CloseHandle hWrite
      Loop
      CloseHandle hRead
    End If
  End If
End Sub


Poziv iz forme:

Code:

dim Komanda as string

Komanda = "ipconfig /all"
Redirect Komanda, Text2


text2 podesiti da je Multiline i ScrollBars both.

Mogli bi recimo napraviti malo bolju winsock kontrolu od ove.
SELECT * FROM หน่วยงานหลัก WHERE ยสันติ LIKE 'โดย%'
 
Odgovor na temu

Shadowed
Vojvodina

Član broj: 649
Poruke: 12851



+4784 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 11:16 - pre 195 meseci
Stvar je u tome da cak i ako javi javnu adresu, to nije potpuni podatak :)
Nemam vb6, bas bih probao kako se ponasa kada imas dve mrezne.
 
Odgovor na temu

dava
Banja Luka

Član broj: 27208
Poruke: 893



+384 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 11:27 - pre 195 meseci
Evo ako ti se da probati napravio sam ti exe koji u txt ispise ip dobijenu winsock kon. (i pride winsock ako zatreba)

SELECT * FROM หน่วยงานหลัก WHERE ยสันติ LIKE 'โดย%'
Prikačeni fajlovi
 
Odgovor na temu

Shadowed
Vojvodina

Član broj: 649
Poruke: 12851



+4784 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 12:57 - pre 195 meseci
Tri IP-a: localhost, mrezna (preko koje se rutira na internet), VPN konekcija - dobio sam IP mrezne sto je naravno tacan ali nepotpun podatak.
 
Odgovor na temu

Eurora3D Team
Nebojsa - Programer & Vodja tima
Beograd

Član broj: 120376
Poruke: 900
91.148.112.*



+7 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 13:04 - pre 195 meseci
@Shadowed Ovaj program gore je samo redirector console output-a. Drugim recima u textBox-u pokazuje isto ono sto bi video u command promtu kad ukucas ipconfig /all i stisnes ENTER
@dava Meni winsock uvek vraca LAN IP a ipconfig vraca IP za sve konekcije (i podatci trebaju da se obrade)
Moje misljenje je da je najbolje da se jednostavno downloaduje ona strana koja pokazuje javnu IP sa neta i da se parsira da bi se dobila spoljasnja IP
... http://checkip.dyndns.org/ ili neka slicna ...
 
Odgovor na temu

dava
Banja Luka

Član broj: 27208
Poruke: 893



+384 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 13:24 - pre 195 meseci
Upravo to ni jedan kod nije dao javnu ip odnosno od rutera, je ja takodje idem preko rutera na int.

Jeste redirekcija, kao i u rajkovom kodu samo sto ne ide preko txt fajla nego direktno vraca VB-u informaciju.
Daj mu komandu "nslookup" odnosno "echo exit|nslookup&exit" da ne bi ostao u pozadini otvoren cmd prozor.
SELECT * FROM หน่วยงานหลัก WHERE ยสันติ LIKE 'โดย%'
 
Odgovor na temu

Eurora3D Team
Nebojsa - Programer & Vodja tima
Beograd

Član broj: 120376
Poruke: 900
91.148.115.*



+7 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 13:30 - pre 195 meseci
Evo da ilustrujem ovaj moj tekst :)
Ovaj VB 6 modul sam napravio za sebe i koristim ga kad mi treba da u VB-u dobijem sploljasnju IP adresu.
Ako vam resenje odgovara slobodno mozete da ga koristite u svojim programima.
FN downloaduje i parsira http://checkip.dyndns.org/ da bi dobila spoljnu IP adresu (kao String). Ako nema konekcije ili dodje do greske vraca prazan string ("")

Koriscenje
Code:

Dim strIP As String
strIP = GetMyWebIP()


Modul
Code:

'modGetMyIP.bas
'CopyRight Eurora3D 2007

Option Explicit

Private Const INTERNET_OPEN_TYPE_PRECONFIG = 0
Private Const INTERNET_FLAG_RELOAD = &H80000000

Private Declare Function InternetOpen Lib "wininet.dll" Alias "InternetOpenA" (ByVal sAgent As String, ByVal lAccessType As Long, ByVal sProxyName As String, ByVal sProxyBypass As String, ByVal lFlags As Long) As Long
Private Declare Function InternetOpenUrl Lib "wininet.dll" Alias "InternetOpenUrlA" (ByVal pub_lngInternetSession As Long, ByVal lpszUrl As String, ByVal lpszHeaders As String, ByVal dwHeadersLength As Long, ByVal dwFlags As Long, ByVal dwContext As Long) As Long
Private Declare Function InternetReadFile Lib "wininet.dll" (ByVal hFile As Long, ByVal sBuffer As String, ByVal lNumBytesToRead As Long, lNumberOfBytesRead As Long) As Integer
Private Declare Function InternetCloseHandle Lib "wininet.dll" (ByVal hInet As Long) As Integer

Public Function GetMyWebIP() As String
On Error GoTo Err
GetMyWebIP = ""
Dim hInternetSession       As Long
Dim hUrlFile               As Long
Dim sReadBuffer            As String * 4096     ' 4k odjednom
Dim sBuffer                As String
Dim lNumberOfBytesRead     As Long
Dim bDoLoop                As Boolean
hInternetSession = InternetOpen("GetMyIP", INTERNET_OPEN_TYPE_PRECONFIG, vbNullString, vbNullString, 0)
If hInternetSession = 0 Then GoTo Err
hUrlFile = InternetOpenUrl(hInternetSession, "http://checkip.dyndns.org/", vbNullString, 0, INTERNET_FLAG_RELOAD, 0)
If hUrlFile = 0 Then GoTo Err
bDoLoop = True
While bDoLoop
   sReadBuffer = ""
      bDoLoop = InternetReadFile(hUrlFile, sReadBuffer, _
                  Len(sReadBuffer), lNumberOfBytesRead)
      sBuffer = sBuffer & Left$(sReadBuffer, lNumberOfBytesRead)
If Not CBool(lNumberOfBytesRead) Then bDoLoop = False
Wend
InternetCloseHandle (hUrlFile)
InternetCloseHandle (hInternetSession)
Dim st As Long, en As Long
st = InStr(1, sBuffer, "Current IP Address: ", vbTextCompare)
If st = 0 Then GoTo Err
st = st + 20
en = InStr(st, sBuffer, "</body>", vbTextCompare)
If en = 0 Then GoTo Err
GetMyWebIP = Mid(sBuffer, st, en - st)
Exit Function
Err:
GetMyWebIP = ""
End Function

 
Odgovor na temu

dava
Banja Luka

Član broj: 27208
Poruke: 893



+384 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 14:26 - pre 195 meseci
E svaka cast.
Mada, ako ce mo sada cjepidlaciti, tvoj kod zavisi od onog servisa na onom sajtu. Nasao sam jedno rjesenje bez vanjskih faktora samo da ga jos realizujem.
SELECT * FROM หน่วยงานหลัก WHERE ยสันติ LIKE 'โดย%'
 
Odgovor na temu

Shadowed
Vojvodina

Član broj: 649
Poruke: 12851



+4784 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 14:34 - pre 195 meseci
Citat:
Eurora3D Team: @Shadowed Ovaj program gore je samo redirector console output-a. Drugim recima u textBox-u pokazuje isto ono sto bi video u command promtu kad ukucas ipconfig /all i stisnes ENTER

Koliko sam shvatio taj program radi sa winsock-om.

Sto se tice ostalog, ako cemo da cepidlacimo, uradis lepo tracert do rootdns-a (ako oni ne rade, to sto ti ne radi program je nebitan problem ) i dobijes sve hop-ove i vidis koji IP-ovi pripadaju privatnim opsezima
 
Odgovor na temu

Eurora3D Team
Nebojsa - Programer & Vodja tima
Beograd

Član broj: 120376
Poruke: 900
91.148.115.*



+7 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 14:58 - pre 195 meseci
@Shadowed nije ... nijedan kod ovde neradi sa Winsock ActiveX (ako si to mislio). Rajkov i Davin kod pozivaju sistemski program ipconfig.exe koji je na WinXP-u u windows\\system32 a moj downloaduje jednu stranu sa neta i u njoj cita spoljnu IP adresu.
@dava Mozemo da cepidlacimo do sutra :) al to radi pa radi . Inace taj servis je stabilan , a ima i drugih slicnih po netu pa treba samo prepraviti zadnji deo funkcije (koji parsira stranu)
Netreba komplikovati ako moze jednostavno ...
 
Odgovor na temu

dava
Banja Luka

Član broj: 27208
Poruke: 893



+384 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 15:01 - pre 195 meseci
Evo probajte sa ovim kodom, meni je pokazao ip rutera:

Code:

Option Explicit

Private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)

Private Sub Command1_Click()
  Dim ts As TextStream, Dat1 As File, Fso As New FileSystemObject
  Dim str As String
  
    Shell "cmd /k netstat /n > c:\1.txt"
    Sleep 500
    Set Dat1 = Fso.GetFile("C:\1.txt")
    Set ts = Dat1.OpenAsTextStream(ForReading)
    Do While Not ts.AtEndOfStream
      
      str = ts.ReadLine
      If Right(str, 8) = "SYN_SENT" Then
          str = Trim(Mid(str, 28))
          str = Mid(str, 1, InStr(1, str, ":") - 1)
          
          Exit Do
      End If
    
    Loop
Print ""
Print "       " & str
End Sub


Na brzinu je pisan tako da nisam provjerio dosta stvari.
SELECT * FROM หน่วยงานหลัก WHERE ยสันติ LIKE 'โดย%'
 
Odgovor na temu

Shadowed
Vojvodina

Član broj: 649
Poruke: 12851



+4784 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 15:13 - pre 195 meseci
Zasto onda u ovoj poruci se attachment zove Winsock.rar i zasto je u njemu i winsock kontrola?
 
Odgovor na temu

Eurora3D Team
Nebojsa - Programer & Vodja tima
Beograd

Član broj: 120376
Poruke: 900
91.148.115.*



+7 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 15:14 - pre 195 meseci
Radi ok ... pravi 1.txt sa aktivnim konekcijama na C:\ disku
Jedino zbog pocetnika kazi da treba da se referencira sa Misrosoft Scripting Runtime zbog FileSystemObject
 
Odgovor na temu

Eurora3D Team
Nebojsa - Programer & Vodja tima
Beograd

Član broj: 120376
Poruke: 900
91.148.115.*



+7 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 15:18 - pre 195 meseci
Citat:
Shadowed: Zasto onda u ovoj poruci se attachment zove Winsock.rar i zasto je u njemu i winsock kontrola? :)

:) A to ... ja to nisam ni video , mislio sam na ove textualne kodove ovde ... taj program verovatno koristi Winsock :)
 
Odgovor na temu

dava
Banja Luka

Član broj: 27208
Poruke: 893



+384 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 16:41 - pre 195 meseci
@Shedowed to sam ti ja poslao exe file (rekao si da nemas VB) a u njemu se nalazi txtbox koji prikazuje winsock1.localIP. Poslao sam ti da isprobas jer sam te razumio da imas dve mrezne karte pa pitas koju bi ip prikazao winsock.

Informacije radi, evo sad sam se kuci zakacio analognim modemom znaci dobio dinamicku adresu od provajdera i winsock kontrola daje upravo tu informaciju. Ali to je samo u ovom slucaju ispravno, dok kod konekcije preko rutera ili nekog proxy-ja ne pije vode. U globalu ipak je @Eurora3D tvoj kod najbolji.
Pozdrav
SELECT * FROM หน่วยงานหลัก WHERE ยสันติ LIKE 'โดย%'
 
Odgovor na temu

Shadowed
Vojvodina

Član broj: 649
Poruke: 12851



+4784 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 16:50 - pre 195 meseci
Ma znam ja, nego Eurora nije video post :)
 
Odgovor na temu

rgdrajko
Beograd

Član broj: 117734
Poruke: 710
80.93.249.*



+3 Profil

icon Re: IP adresa u Visual basicu22.04.2008. u 17:44 - pre 195 meseci
Evo jos jedan program za IP address.

Forma:
Code:

Option Explicit

Private Sub Command1_Click()
    Dim IPAddress As String
    IPAddress = GetWanIP()
    Label2.Caption = IPAddress
End Sub


Modul:
Code:
Option Explicit

'in a module:
'******************************************************************
'Origin Created By Verburgh Peter.
'Modified By TapTapYu ([email protected])
'The origin example to get the list of IP already very good, i modified it, so
'if user is connected to internet, it will not return the Lan IP
'******************************************************************
Const MAX_IP = 5 'To make a buffer... i dont think you have more than 5 ip on your pc..
Type IPINFO
     dwAddr As Long ' IP address
    dwIndex As Long ' interface index
    dwMask As Long ' subnet mask
    dwBCastAddr As Long ' broadcast address
    dwReasmSize As Long ' assembly size
    unused1 As Integer ' not currently used
    unused2 As Integer '; not currently used
End Type
Type MIB_IPADDRTABLE
    dEntrys As Long 'number of entries in the table
    mIPInfo(MAX_IP) As IPINFO 'array of IP address entries
End Type
Type IP_Array
    mBuffer As MIB_IPADDRTABLE
    BufferLen As Long
End Type
Public Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (Destination As Any, Source As Any, ByVal Length As Long)
Public Declare Function GetIpAddrTable Lib "IPHlpApi" (pIPAdrTable As Byte, pdwSize As Long, ByVal Sort As Long) As Long
'converts a Long to a string
Public Function ConvertAddressToString(longAddr As Long) As String
    Dim myByte(3) As Byte
    Dim Cnt As Long
    CopyMemory myByte(0), longAddr, 4
    For Cnt = 0 To 3
        ConvertAddressToString = ConvertAddressToString + CStr(myByte(Cnt)) + "."
    Next Cnt
    ConvertAddressToString = Left$(ConvertAddressToString, Len(ConvertAddressToString) - 1)
End Function
Public Function GetWanIP() As String
Dim Ret As Long, Tel As Long
Dim bBytes() As Byte
Dim TempList() As String
Dim TempIP As String
Dim Tempi As Long
Dim Listing As MIB_IPADDRTABLE
Dim L3 As String
 
On Error GoTo END1
    GetIpAddrTable ByVal 0&, Ret, True
 
    If Ret <= 0 Then Exit Function
    ReDim bBytes(0 To Ret - 1) As Byte
    ReDim TempList(0 To Ret - 1) As String
 
    'retrieve the data
    GetIpAddrTable bBytes(0), Ret, False
 
    'Get the first 4 bytes to get the entry's.. ip installed
    CopyMemory Listing.dEntrys, bBytes(0), 4
 
    For Tel = 0 To Listing.dEntrys - 1
        'Copy whole structure to Listing..
        CopyMemory Listing.mIPInfo(Tel), bBytes(4 + (Tel * Len(Listing.mIPInfo(0)))), Len(Listing.mIPInfo(Tel))
        TempList(Tel) = ConvertAddressToString(Listing.mIPInfo(Tel).dwAddr)
    Next Tel
    
    'Sort Out The IP For WAN
        TempIP = TempList(0)

'        For Tempi = 0 To Listing.dEntrys - 1
'            L3 = Left(TempList(Tempi), 3)
'            If L3 <> "169" And L3 <> "127" And L3 <> "192" Then
'                TempIP = TempList(Tempi)
'            End If
'        Next Tempi

        GetWanIP = TempIP 'Return The TempIP
Exit Function
END1:
GetWanIP = ""
End Function

rgdrajko
Prikačeni fajlovi
 
Odgovor na temu

[es] :: Visual Basic 6 :: IP adresa u Visual basicu

Strane: 1 2

[ Pregleda: 5630 | Odgovora: 36 ] > FB > Twit

Postavi temu Odgovori

Navigacija
Lista poslednjih: 16, 32, 64, 128 poruka.