zoukankan      html  css  js  c++  java
  • [转]用C#获取局域网内所有机器

    原理其实很简单,在cmd.exe下面ping一下几台机,然后用arp -a命令查看一下,这种方式比开多线程去循环扫描的方式来的简单而有效。
    //首先来个循环ping一下那个网段的主机。
    //其次用以下的函数去获取所有的局域网内有响应的ip地址列表
    public static ArrayList GetAllLocalMachines()
    {   
     Process p = new Process();   
     p.StartInfo.FileName = "cmd.exe";   
     p.StartInfo.UseShellExecute = false;   
     p.StartInfo.RedirectStandardInput = true;   
     p.StartInfo.RedirectStandardOutput = true;   
     p.StartInfo.RedirectStandardError = true;   
     p.StartInfo.CreateNoWindow = true;   
     p.Start();   
     p.StandardInput.WriteLine("arp -a");   
     p.StandardInput.WriteLine("exit");   
     ArrayList list = new ArrayList();   
     StreamReader reader = p.StandardOutput;   
     string IPHead = Dns.GetHostByName(Dns.GetHostName()).AddressList[0].ToString().Substring(0, 3);   
     for (string line = reader.ReadLine(); line != null; line = reader.ReadLine())   
     {       
      line = line.Trim();       
      if (line.StartsWith(IPHead) && (line.IndexOf("dynamic") != -1))       
      {           
       string IP = line.Substring(0, 15).Trim();           
       string Mac = line.Substring(line.IndexOf("-") - 2, 0x11).Trim();           
       LocalMachine localMachine = new LocalMachine();           
       localMachine.MachineIP = IP;           
       localMachine.MachineMAC = Mac;           
       localMachine.MachineName = "";           
       list.Add(localMachine);       
      }   
     }   
     return list;
    }
  • 相关阅读:
    剑指offer-翻转单词序列
    剑指offer-丑数
    剑指offer-把数组排成最小的数
    mysql笔记(13)-视图的概念和使用
    mysql笔记(12)-外键约束的添加和删除
    mysql笔记(11)-约束的添加、修改和删除
    mysql笔记(10)-数据的插入和更新(insert/update/case)
    mysql笔记(9)-表的创建和删除(drop/truncate/delete)
    mysql笔记(8)-嵌套查询之in、exists
    mysql笔记(7)-多表查询之自然连接、外连接
  • 原文地址:https://www.cnblogs.com/lifuyun/p/lifuyun090926.html
Copyright © 2011-2022 走看看