Click here to Skip to main content
6,634,665 members and growing! (16,566 online)
Email Password   helpLost your password?
Languages » VB.NET » General     Intermediate

Build Simple Network Browser

By aleksisa

Build Simple Network Browser to Enumerate Computers and Users on the Local Network
VB, Windows, .NET, Visual Studio, Dev
Posted:9 Jan 2007
Views:35,435
Bookmarked:43 times
Unedited contribution
Announcements
Loading...
 
Search    
Advanced Search
Add to IE Search
printPrint   add Share
      Discuss Discuss   Broken Article?Report  
18 votes for this article.
Popularity: 4.21 Rating: 3.35 out of 5
2 votes, 11.1%
1
1 vote, 5.6%
2

3
4 votes, 22.2%
4
11 votes, 61.1%
5

Introduction

While working on SQL Server management tool for mobile devices - Siccolo, I created a simple applet to be able to browse computers on the local network within a domain and retrieve additional information (such as list of users, services).
See more at Articles from Siccolo!

The code presented allows to build simple network browser

Using the code

.NET allows to retrieve almost any information about local network by using WMI - Windows Management Instrumentation - service with ManagementObjectSearcher class and in conjunction with Active Directory Service Interfaces (ADSI) - Active Directory hierarchy.

The code is broken into several methods:

  1. Get Domain Name location computer belongs to:

        // VB.NET //
        ...
       Public Function GetLocalComputerInfo() As Boolean
    
            Dim query As <CODE>ManagementObjectSearcher
            Dim queryCollection As ManagementObjectCollection
    
            Dim query_command As String = "SELECT * FROM Win32_ComputerSystem"
    
            Dim msc As ManagementScope = New ManagementScope("root\cimv2")
    
            Dim select_query As SelectQuery = New SelectQuery(query_command)
    
            query = New ManagementObjectSearcher(msc, select_query)
            queryCollection = query.Get()
    
            Dim management_object As ManagementObject
    
            For Each management_object In queryCollection
                m_local_domain_name = management_object("Domain")
                m_local_computer_name = management_object("Name")
            Next management_object
    
            Return True
        End Function
        ...
    
    where:
    msc As ManagementScope sets a scope for management operations - defines the WMI namespace in which management operations are performed.

    Once domain name is known, we are able to retrieve list of computers within that domain.

  2. Enumerate computers within a domain:

        // VB.NET //
        ...
        Public Function GetComputersInfoCollection(ByVal domain As String) _
    As DirectoryEntry Dim domainEntry As DirectoryEntry = New DirectoryEntry("WinNT://" _
    + domain) domainEntry.Children.SchemaFilter.Add("computer") Return domainEntry End Function ...
    where:
    method returns instance of DirectoryEntry - node in in the Active Directory hierarchy. that corresponds to the given domain.

    Next, let's retrieve list of users that belong to that domain.

  3. Enumerate users within a domain:

        // VB.NET //
        ...
        Public Function GetUsersInfoCollection(ByVal domain As String) _ 
    As ManagementObjectCollection Dim query As ManagementObjectSearcher Dim queryCollection As ManagementObjectCollection Dim msc As ManagementScope = New ManagementScope("root\cimv2") Dim query_command As String = _ "SELECT * FROM Win32_UserAccount WHERE Domain=" & _ Chr(34).ToString() & domain & Chr(34).ToString() 'Win32_UserAccount: 'see http://msdn.microsoft.com/library/default.asp?
    'url=/library/en-us/wmisdk/wmi/win32_useraccount.asp
    'class Win32_UserAccount : Win32_Account '{ ' uint32 AccountType; ' string Caption; ' string Description; ' boolean Disabled; ' string Domain; ' string FullName; ' datetime InstallDate; ' boolean LocalAccount; ' boolean Lockout; ' string Name; ' boolean PasswordChangeable; ' boolean PasswordExpires; ' boolean PasswordRequired; ' string SID; ' uint8 SIDType; ' string Status; '}; ' Dim select_query As SelectQuery = New SelectQuery(query_command) query = New ManagementObjectSearcher(msc, select_query) queryCollection = query.Get() Return queryCollection End Function ...


    In addition to be able to retrieve above information, we can also obtain services collection for a given machine:

  4. Enumerate services on a computer using WMI:


        // VB.NET //
        ...
        Public Function GetServicesInfoCollection(ByVal computer_name _
    As String) _
    As ManagementObjectCollection Dim query As ManagementObjectSearcher Dim queryCollection As ManagementObjectCollection Dim msc As ManagementScope = New ManagementScope("\\" &_
    computer_name & "
    \root\cimv2") Dim query_command As String = "SELECT * FROM Win32_Service" 'Win32_UserAccount: 'see http://msdn.microsoft.com/library/en-us/wmisdk/wmi/
    'win32_service.asp?frame=true
    ' ' class Win32_Service : Win32_BaseService '{ ' boolean AcceptPause; ' boolean AcceptStop; ' string Caption; ' uint32 CheckPoint; ' string CreationClassName; ' string Description; ' boolean DesktopInteract; ' string DisplayName; ' string ErrorControl; ' uint32 ExitCode; ' datetime InstallDate; ' string Name; ' string PathName; ' uint32 ProcessId; ' uint32 ServiceSpecificExitCode; ' string ServiceType; ' boolean Started; ' string StartMode; ' string StartName; ' string State; ' string Status; ' string SystemCreationClassName; ' string SystemName; ' uint32 TagId; ' uint32 WaitHint; '}; Dim select_query As SelectQuery = New SelectQuery(query_command) query = New ManagementObjectSearcher(msc, select_query) queryCollection = query.Get() Return queryCollection End Function ...

    Points of Interest

    If you would like to read more - please take a look at Siccolo - Free Mobile Management Tool For SQL Server and more articles at Development Articles from Siccolo!

    History

    no improvements so far. nearly perfect.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

About the Author

aleksisa


Member

Location: United States United States

Other popular VB.NET articles:

Article Top
You must Sign In to use this message board.
FAQ FAQ 
 
Noise Tolerance  Layout  Per page   
 Msgs 1 to 13 of 13 (Total in Forum: 13) (Refresh)FirstPrevNext
Generalaccess denied Pinmembercemalpcstore4:28 27 Feb '07  
GeneralRe: access denied Pinmemberaleksisa17:18 27 Feb '07  
QuestionHow to retrive Shared Files(not folder) using WMI Pinmemberi_razi10:01 23 Feb '07  
AnswerRe: How to retrive Shared Files(not folder) using WMI Pinmemberaleksisa7:21 26 Feb '07  
GeneralNew key word missing form variable definitions PinmemberToothRobber9:50 16 Jan '07  
GeneralErrors and No Source Code Pinmemberhswear319:45 15 Jan '07  
GeneralRe: Errors and No Source Code Pinmemberaleksisa5:39 16 Jan '07  
GeneralManagementObject PinmemberJaeman16:26 15 Jan '07  
GeneralRe: ManagementObject Pinmemberaleksisa5:36 16 Jan '07  
GeneralRe: ManagementObject PinmemberJaeman19:08 16 Jan '07  
GeneralWhen running your application NullReferenceException PinmemberToothRobber8:49 15 Jan '07  
GeneralSource Code for your application? PinmemberToothRobber8:48 15 Jan '07  
GeneralRe: Source Code for your application? Pinmemberaleksisa5:41 16 Jan '07  

General General    News News    Question Question    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

PermaLink | Privacy | Terms of Use
Last Updated: 9 Jan 2007
Editor:
Copyright 2007 by aleksisa
Everything else Copyright © CodeProject, 1999-2009
Web20 | Advertise on the Code Project