Visualizzazione dei risultati da 1 a 9 su 9
  1. #1

    [VB6] Lista processi attivi da remoto

    Ciao a tutti,

    E' possibile, tramite visual basic ricavare la lista di processi attivi su un macchina remota tramite indirizzo IP?

    Ho trovato un programma che lo fa di per se (pslist) che non mi soddisfa in quanto sviluppo il tutto in una finestra DOS.

    Io vorrei memorizzare il tutto in un array


    Grazie in anticipo

  2. #2
    Utente di HTML.it L'avatar di oregon
    Registrato dal
    Jul 2005
    residenza
    Roma
    Messaggi
    36,480
    Ti avevo detto come fare nell'altro thread ...

    Hai i dati che vuoi nell'array dopo avere letto il file che ti genera pslist.

    Esiste anche il tool tasklist per fare la stessa cosa.

    Perche' non va ?

  3. #3
    Originariamente inviato da oregon
    Ti avevo detto come fare nell'altro thread ...

    Hai i dati che vuoi nell'array dopo avere letto il file che ti genera pslist.

    Esiste anche il tool tasklist per fare la stessa cosa.

    Perche' non va ?
    Ecco come faccio ...
    codice:
    Sub avvia()
    con = conn.conn.ConnectionString
    
    
    
    
    Open App.Path & "\config.cfg" For Input As #1
    Do While Not EOF(1)
        Line Input #1, pass
    Loop
    Close #1
    rs.Open "select * from postazioni", con, 3, 3
    n = rs.RecordCount
    ProgressBar1.Max = n
    Do While Not rs.EOF
    ip = rs("ip")
            t = Shell("cmd /c pslist \\" & ip & " -u administrator -p " & pass & " " & txtprocesso.Text & " >c:\output.txt", 1)
          
            Delay 4
            Open "c:\output.txt" For Input As #2
            
            Do While Not EOF(2)
            Line Input #2, filedata
            dati = Replace(filedata, " ", vbTab)
            extr = Split(dati, vbTab)
            On Error Resume Next
            nome = extr(0)
            
            
            
                If nome = txtprocesso.Text Then
                
                    cmd.ActiveConnection = conn.conn.ConnectionString
                    cmd.CommandText = "update postazioni set libero = 'occupato' where ip ='" & ip & "'"
                    cmd.Execute
                    GoTo line1
                    
                    occupate = occupate + 1
                    
                    lbloccupate.Caption = occupate
                End If
                
            Loop
            cmd.ActiveConnection = conn.conn.ConnectionString
            cmd.CommandText = "update postazioni set libero = 'libero' where ip ='" & ip & "'"
            cmd.Execute
            
          libere = libere + 1
          lblLibere.Caption = libere
    line1:
            Close #2
            rs.MoveNext
            ProgressBar1.Value = ProgressBar1.Value + 1
            
            nome = ""
    Loop
    
    'MsgBox "Trovate " & libere & " postazioni libere\n e " & occupate & " postazioni occupate", vbInformation
    Timeout.Enabled = True
    End Sub
    Il problema è che a volte la finestra di dos rimane aperta, il ciclo si blocca e rimango fregato...

    Dovrei trovare un modo per far continuare il programma solo le la finestra di Dos è chiusa

    Sai suggerirmi qualcosa?


    Grazie Tante

  4. #4
    Utente di HTML.it L'avatar di oregon
    Registrato dal
    Jul 2005
    residenza
    Roma
    Messaggi
    36,480
    Originariamente inviato da simcario
    Il problema è che a volte la finestra di dos rimane aperta, il ciclo si blocca e rimango fregato...

    Dovrei trovare un modo per far continuare il programma solo le la finestra di Dos è chiusa

    Sai suggerirmi qualcosa?

    Grazie Tante
    Non ha molto senso cominciare un altro thread sullo stesso problema se la soluzione c'e'. Il fatto che la Shell debba essere sincrona lo risolvi non utilizzando l'istruzione Shell ma il codice che segue (suggerito da MS stessa ...)

    Nel form inserisci le seguenti dichiarazioni di strutture, costanti e API

    codice:
    Private Type STARTUPINFO
       cb As Long
       lpReserved As String
       lpDesktop As String
       lpTitle As String
       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 Long
       hStdInput As Long
       hStdOutput As Long
       hStdError As Long
    End Type
    
    Private Type PROCESS_INFORMATION
       hProcess As Long
       hThread As Long
       dwProcessID As Long
       dwThreadID As Long
    End Type
    
    Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal _
       hHandle As Long, ByVal dwMilliseconds As Long) As Long
    
    Private Declare Function CreateProcessA Lib "kernel32" (ByVal _
       lpApplicationName As String, ByVal lpCommandLine As String, ByVal _
       lpProcessAttributes As Long, ByVal lpThreadAttributes As Long, _
       ByVal bInheritHandles As Long, ByVal dwCreationFlags As Long, _
       ByVal lpEnvironment As Long, ByVal lpCurrentDirectory As String, _
       lpStartupInfo As STARTUPINFO, lpProcessInformation As _
       PROCESS_INFORMATION) As Long
    
    Private Declare Function CloseHandle Lib "kernel32" _
       (ByVal hObject As Long) As Long
    
    Private Declare Function GetExitCodeProcess Lib "kernel32" _
       (ByVal hProcess As Long, lpExitCode As Long) As Long
    
    Private Const NORMAL_PRIORITY_CLASS = &H20&
    Private Const INFINITE = -1&
    aggiungi la funzione che segue

    codice:
    Private Function ExecCmd(cmdline As String)
        Dim ret As Long
        Dim proc As PROCESS_INFORMATION
        Dim start As STARTUPINFO
        
        start.cb = Len(start)
        
        ret = CreateProcessA(vbNullString, cmdline, 0&, 0&, 1&, _
                             NORMAL_PRIORITY_CLASS, 0&, vbNullString, start, proc)
        
        ret = WaitForSingleObject(proc.hProcess, INFINITE)
        Call GetExitCodeProcess(proc.hProcess, ret&)
        Call CloseHandle(proc.hThread)
        Call CloseHandle(proc.hProcess)
        
        ExecCmd = ret
    End Function
    e, nel tuo codice, elimina l'istruzione Shell sostituendola con

    codice:
    ret = ExecCmd("cmd /c pslist \\" & ip & " -u administrator -p " & pass & " " & txtprocesso.Text & " >c:\output.txt", 1)
    in cui ret e' una variabile Long (non dimenticare di dichiarare esplicitamente tutte le variabili ... usa Option Explicit sempre nel tuo codice ...) che puoi esaminare prima di continuare nel codice per capire se c'e' stato un problema. Se e' 0 allora puoi continuare eliminando il Delay ...

  5. #5
    Grazie tante

  6. #6
    Utente di HTML.it L'avatar di oregon
    Registrato dal
    Jul 2005
    residenza
    Roma
    Messaggi
    36,480
    Figurati. Ma hai risolto? Funziona?

  7. #7
    Ho risolto ma con la shell cercando di gestire tutti gli eventuali errori.

  8. #8
    Utente di HTML.it L'avatar di oregon
    Registrato dal
    Jul 2005
    residenza
    Roma
    Messaggi
    36,480
    Originariamente inviato da simcario
    Ho risolto ma con la shell cercando di gestire tutti gli eventuali errori.
    La shell e' asincrona ... se il processo non e' terminato non hai un file in output che abbia un senso ...

    Potresti continuare ad avere problemi ...

    Ovviamente scegli la strada che credi ...

  9. #9
    Hai ragione,

    per il momento ho scelto questa trada perchè è un progetto di prova..
    ma ovviamente nel progetto definitivo scegliero la strada giusta..

    La strasa "Sincrona" ho intenzione di sceglierla quando avrò un po di tempo per poterla studiare

    Questo è un progetto abbastanza urgente ed è solo di prova...

    non mi va di ammazzarmi per niente...

    Comunque accetto volentieri il tuo consiglio

    Grazie tante

Permessi di invio

  • Non puoi inserire discussioni
  • Non puoi inserire repliche
  • Non puoi inserire allegati
  • Non puoi modificare i tuoi messaggi
  •  
Powered by vBulletin® Version 4.2.1
Copyright © 2025 vBulletin Solutions, Inc. All rights reserved.