Помогиде проверить комп. удалённо

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
tattoomen
Начинающий
Начинающий
 
Сообщения: 6
Зарегистрирован: 09.11.2005 (Ср) 7:49

Помогиде проверить комп. удалённо

Сообщение tattoomen » 09.11.2005 (Ср) 9:44

Добрый день. помогите организовать условие, проверить если включен компьютер или присутствует ли компьютер с именем например u12 в локальной сети домена допустим f1f Если включен то допустим выполняеться Действие1 а если выключен то Действие2. мне в первую очередь важен сам процесс проверки, конечно буду очень признателен если напишете вместе с условием. Спасибо...
Если очень сильно захотеть то любая девушка будет лежать у моих ног, главное точно попасть в челюсть!

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 09.11.2005 (Ср) 9:46

Что является критерием включенности компа?
Удачный пинг?
Lasciate ogni speranza, voi ch'entrate.

tattoomen
Начинающий
Начинающий
 
Сообщения: 6
Зарегистрирован: 09.11.2005 (Ср) 7:49

Сообщение tattoomen » 09.11.2005 (Ср) 9:48

alibek писал(а):Что является критерием включенности компа?
Удачный пинг?

Наверно да. :roll: Если нет пинга я так понимаю нет и компа в сети(значет он выключен или отключен). Да.
Если очень сильно захотеть то любая девушка будет лежать у моих ног, главное точно попасть в челюсть!

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 09.11.2005 (Ср) 9:52

Если нет пинга, то может быть просто включен файрвол на компе.
Но если он тебя устраивает, то поищи по слову "icmp", уже было.
Есть даже это, если пример рабочий, то он будет лучше, чем пинг.
Lasciate ogni speranza, voi ch'entrate.

tattoomen
Начинающий
Начинающий
 
Сообщения: 6
Зарегистрирован: 09.11.2005 (Ср) 7:49

Сообщение tattoomen » 09.11.2005 (Ср) 11:24

Давайте исходить из того что я совсем чайник в vbe. Как пользоваться пингом? как его подключить? мне в конце концов нужно чтобы после проверки результат помещался в таблицу Excel ( организовать с помощью макроса в excel книге.) я конечно понимаю что можно дать ссылку на код которй я незнаю куда поместить... Желательно чтобы всё событие было на кнопке. Кто нить помогите.
Если очень сильно захотеть то любая девушка будет лежать у моих ног, главное точно попасть в челюсть!

bayasaa
Обычный пользователь
Обычный пользователь
Аватара пользователя
 
Сообщения: 93
Зарегистрирован: 13.08.2005 (Сб) 11:57
Откуда: Mongolia

Сообщение bayasaa » 09.11.2005 (Ср) 14:29

Этот пример работает как пинг. Попробуй, а насчёт Excel-а извини не знаю
Код: Выделить всё

Const SOCKET_ERROR = 0
Private Type WSAdata
    wVersion As Integer
    wHighVersion As Integer
    szDescription(0 To 255) As Byte
    szSystemStatus(0 To 128) As Byte
    iMaxSockets As Integer
    iMaxUdpDg As Integer
    lpVendorInfo As Long
End Type
Private Type Hostent
    h_name As Long
    h_aliases As Long
    h_addrtype As Integer
    h_length As Integer
    h_addr_list As Long
End Type
Private Type IP_OPTION_INFORMATION
    TTL As Byte
    Tos As Byte
    Flags As Byte
    OptionsSize As Long
    OptionsData As String * 128
End Type
Private Type IP_ECHO_REPLY
    Address(0 To 3) As Byte
    Status As Long
    RoundTripTime As Long
    DataSize As Integer
    Reserved As Integer
    data As Long
    Options As IP_OPTION_INFORMATION
End Type
Private Declare Function GetHostByName Lib "wsock32.dll" Alias "gethostbyname" (ByVal HostName As String) As Long
Private Declare Function WSAStartup Lib "wsock32.dll" (ByVal wVersionRequired&, lpWSAdata As WSAdata) As Long
Private Declare Function WSACleanup Lib "wsock32.dll" () As Long
Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (hpvDest As Any, hpvSource As Any, ByVal cbCopy As Long)
Private Declare Function IcmpCreateFile Lib "icmp.dll" () As Long
Private Declare Function IcmpCloseHandle Lib "icmp.dll" (ByVal HANDLE As Long) As Boolean
Private Declare Function IcmpSendEcho Lib "ICMP" (ByVal IcmpHandle As Long, ByVal DestAddress As Long, ByVal RequestData As String, ByVal RequestSize As Integer, RequestOptns As IP_OPTION_INFORMATION, ReplyBuffer As IP_ECHO_REPLY, ByVal ReplySize As Long, ByVal TimeOut As Long) As Boolean

Private Sub Command1_Click()
    Dim hFile As Long, lpWSAdata As WSAdata
    Dim hHostent As Hostent, AddrList As Long
    Dim Address As Long, rIP As String
    Dim OptInfo As IP_OPTION_INFORMATION
    Dim EchoReply As IP_ECHO_REPLY
    Call WSAStartup(&H101, lpWSAdata)
    HostName = Text1.Text
    If GetHostByName(HostName + String(64 - Len(HostName), 0)) <> SOCKET_ERROR Then
        CopyMemory hHostent.h_name, ByVal GetHostByName(HostName + String(64 - Len(HostName), 0)), Len(hHostent)
        CopyMemory AddrList, ByVal hHostent.h_addr_list, 4
        CopyMemory Address, ByVal AddrList, 4
    End If
    hFile = IcmpCreateFile()
    If hFile = 0 Then
        MsgBox "Unable to Create File Handle"
        Exit Sub
    End If
    OptInfo.TTL = 255
    If IcmpSendEcho(hFile, Address, String(32, "A"), 32, OptInfo, EchoReply, Len(EchoReply) + 8, 2000) Then
        rIP = CStr(EchoReply.Address(0)) + "." + CStr(EchoReply.Address(1)) + "." + CStr(EchoReply.Address(2)) + "." + CStr(EchoReply.Address(3))
        MsgBox "есть "CStr(EchoReply.Address(0)) + "." + CStr(EchoReply.Address(1)) + "." + CStr(EchoReply.Address(2)) + "." + CStr(EchoReply.Address(3))
    Else
        MsgBox "не отвечает"
    End If
    If EchoReply.Status = 0 Then
        MsgBox "Reply from " + HostName + " (" + rIP + ") recieved after " + Trim$(CStr(EchoReply.RoundTripTime)) + "ms"
         MsgBox HostName + " есть в сети"

    Else
        MsgBox HostName + " не отвечает"
    End If
    Call IcmpCloseHandle(hFile)
    Call WSACleanup
End Sub


tattoomen
Начинающий
Начинающий
 
Сообщения: 6
Зарегистрирован: 09.11.2005 (Ср) 7:49

Сообщение tattoomen » 10.11.2005 (Чт) 6:20

Сенкъю вери мач. :lol: заработало.... :lol:

Код: Выделить всё
Private Sub CommandButton1_Click()
On Error Resume Next
uz = 1
For i = 2 To Worksheets("user").Range("A1")
uz = uz + 1
    Dim hFile As Long, lpWSAdata As WSAdata
    Dim hHostent As Hostent, AddrList As Long
    Dim Address As Long, rIP As String
    Dim OptInfo As IP_OPTION_INFORMATION
    Dim EchoReply As IP_ECHO_REPLY
    Call WSAStartup(&H101, lpWSAdata)
    HostName = Worksheets("user").Range("A" & uz) '---------------------------------
   
    If GetHostByName(HostName + String(64 - Len(HostName), 0)) <> SOCKET_ERROR Then
        CopyMemory hHostent.h_name, ByVal GetHostByName(HostName + String(64 - Len(HostName), 0)), Len(hHostent)
        CopyMemory AddrList, ByVal hHostent.h_addr_list, 4
        CopyMemory Address, ByVal AddrList, 4
    End If
    hFile = IcmpCreateFile()
    If hFile = 0 Then
        MsgBox "Unable to Create File Handle"
        Exit Sub
    End If
 
     OptInfo.TTL = 255
    If IcmpSendEcho(hFile, Address, String(32, "A"), 32, OptInfo, EchoReply, Len(EchoReply) + 8, 2000) Then
        rIP = CStr(EchoReply.Address(0)) + "." + CStr(EchoReply.Address(1)) + "." + CStr(EchoReply.Address(2)) + "." + CStr(EchoReply.Address(3))
       'åñòü"
    Else
       'íå îòâå÷àåò"
    End If
    If EchoReply.Status = 0 Then
         ' åñòü â ñåòè"
         Set fs = CreateObject("Scripting.FileSystemObject")
     Set d = fs.GetDrive(fs.GetDriveName("\\" + HostName + "\c$")) '----------------- äèñê c:
     si = d.FreeSpace
     Worksheets("l1").Range("A" & i).FormulaR1C1 = HostName 'çàïèñü äàííûõ â ÿ÷åéêó
     Worksheets("l1").Range("B" & i).FormulaR1C1 = "C:\"
     Worksheets("l1").Range("C" & i).FormulaR1C1 = Round(si / 1048576, 2)
     Worksheets("l1").Range("D" & i).FormulaR1C1 = Date & " " & Time
     Worksheets("l1").Range("E" & i).FormulaR1C1 = "OnLine"
     Set fs = CreateObject("Scripting.FileSystemObject")
     Set d = fs.GetDrive(fs.GetDriveName("\\" + HostName + "\d$")) '----------------- äèñê d:
     si = d.FreeSpace
     i = i + 1
     Worksheets("l1").Range("A" & i).FormulaR1C1 = "---" 'çàïèñü äàííûõ â ÿ÷åéêó
     Worksheets("l1").Range("B" & i).FormulaR1C1 = "D:\"
     Worksheets("l1").Range("C" & i).FormulaR1C1 = Round(si / 1048576, 2)
    Else
    Worksheets("l1").Range("A" & i).FormulaR1C1 = HostName
    Worksheets("l1").Range("B" & i).FormulaR1C1 = "C:\"
        ' HostName + " íå îòâå÷àåò"
        Worksheets("l1").Range("E" & i).FormulaR1C1 = "OffLine"
        Worksheets("l1").Range("D" & i).FormulaR1C1 = Date & " " & Time
        i = i + 1
        Worksheets("l1").Range("A" & i).FormulaR1C1 = "---" 'çàïèñü äàííûõ â ÿ÷åéêó
        Worksheets("l1").Range("B" & i).FormulaR1C1 = "D:\"
    End If
   
    Call IcmpCloseHandle(hFile)
    Call WSACleanup
   
    Next i
End Sub


Вернуться в Visual Basic 1–6

Кто сейчас на конференции

Сейчас этот форум просматривают: SemrushBot и гости: 147

    TopList