运用C++对物理网卡/设想网卡进行辨认(包罗内外网筛选)

简介

在Socket编制程序的时候,大家须求实时获取大家所急需的IP地址。举例在编排后门的时候,大家大概需求获得有效的外网IP或内网IP;有的时候候我们可能须求看清大家得到的是或不是是设想机网卡,这时候就必要对每一张网卡上的表征进行鉴定区别。以下我总括了一些常用的拍卖形式供我们参谋。

参照他事他说加以考察资料:1.
领到网卡音信情势
              2.
虚拟与物理网卡区分方法

长期以来,好像从没一段正式的代码能提供Android设备此时的IP地址,究其原因,Android设备的网卡恐怕非但三个,如蜂窝网卡、WiFi网卡,而且同二个网卡也说不定持有持续一个IP地址。基于此,三个Android终端很有非常大希望同期持有几个IP地址(不只是同有的时候间兼有IPv4和IPv6地址),比方敞开火热分享蜂窝网络的时候,蜂窝网卡具备三个IPv4地址来拜候外网,WiFi网卡具有八个IPv4地址来作为内网的网关。

获得本机全部IP地址:

string name = Dns.GetHostName();
IPAddress[] ipadrlist = Dns.GetHostAddresses(name);

         那一个地址是含有全数网卡(设想网卡)的ipv4和ipv6地址。

本文首要商量的是使用Python获取本机全体网卡ip,掩码和播放地址,分享了相关的实例代码,具体介绍如下。

C++代码样例

网络比较盛行的拿走Android设备IP地址的代码有以下二种,上面大家来千家万户深入分析一下。

获取本机全数IPV4地址:

string name = Dns.GetHostName();
IPAddress[] ipadrlist = Dns.GetHostAddresses(name);
foreach (IPAddress ipa in ipadrlist)
{
            if (ipa.AddressFamily == AddressFamily.InterNetwork)
            Console.Writeline(ipa.ToString());
}

        若要单单获取ipv4地址,能够用IPAdress.AddressFamily
属性判别:对于 IPv4,重返 InterNetwork;对于 IPv6,重临 InterNetworkV6。

       
可是一旦本机恐怕有五个ipv4的地址,那怎么得到访问暗中认可网关时使用的网卡IP呢。在CSDN论坛找到了大神的格局,用的是查询本机路由表。

获得本机正在利用的ipv4地址(访谈互连网的IP),可别小看,照旧有好多急需考虑的:
1.三个Computer有八个网卡,有线的、有线的、还也可以有vmare设想的多少个网卡。
2.固然独有多个网卡,不过该网卡配置了N个IP地址.在那之中还包蕴ipv6地址。

上面贴四个作者一直使用的章程,它通过查询本机路由表,获取访谈暗许网关时使用的网卡IP。
用了2年了,屡试不爽。

      /// <summary>
        /// 获取当前使用的IP
        /// </summary>
        /// <returns></returns>
        public static string GetLocalIP()
        {
            string result = RunApp("route", "print",true);
            Match m = Regex.Match(result, @"0.0.0.0\s+0.0.0.0\s+(\d+.\d+.\d+.\d+)\s+(\d+.\d+.\d+.\d+)");
            if (m.Success)
            {
                return m.Groups[2].Value;
            }
            else
            {
                try
                {
                    System.Net.Sockets.TcpClient c = new System.Net.Sockets.TcpClient();
                    c.Connect("www.baidu.com", 80);
                    string ip = ((System.Net.IPEndPoint)c.Client.LocalEndPoint).Address.ToString();
                    c.Close();
                    return ip;
                }
                catch (Exception)
                {
                    return null;
                }
            }
        }

        /// <summary>
        /// 获取本机主DNS
        /// </summary>
        /// <returns></returns>
        public static string GetPrimaryDNS()
        {
            string result = RunApp("nslookup", "",true);
            Match m = Regex.Match(result, @"\d+\.\d+\.\d+\.\d+");
            if (m.Success)
            {
                return m.Value;
            }
            else
            {
                return null;
            }
        }

        /// <summary>
        /// 运行一个控制台程序并返回其输出参数。
        /// </summary>
        /// <param name="filename">程序名</param>
        /// <param name="arguments">输入参数</param>
        /// <returns></returns>
        public static string RunApp(string filename, string arguments,bool recordLog)
        {
            try
            {
                if (recordLog)
                {
                    Trace.WriteLine(filename + " " + arguments);
                }
                Process proc = new Process();
                proc.StartInfo.FileName = filename;
                proc.StartInfo.CreateNoWindow = true;
                proc.StartInfo.Arguments = arguments;
                proc.StartInfo.RedirectStandardOutput = true;
                proc.StartInfo.UseShellExecute = false;
                proc.Start();

                using (System.IO.StreamReader sr = new System.IO.StreamReader(proc.StandardOutput.BaseStream, Encoding.Default))
                {
                    //string txt = sr.ReadToEnd();
                    //sr.Close();
                    //if (recordLog)
                    //{
                    //    Trace.WriteLine(txt);
                    //}
                    //if (!proc.HasExited)
                    //{
                    //    proc.Kill();
                    //}
                    //上面标记的是原文,下面是我自己调试错误后自行修改的
                    Thread.Sleep(100);           //貌似调用系统的nslookup还未返回数据或者数据未编码完成,程序就已经跳过直接执行
                                                 //txt = sr.ReadToEnd()了,导致返回的数据为空,故睡眠令硬件反应
                    if (!proc.HasExited)         //在无参数调用nslookup后,可以继续输入命令继续操作,如果进程未停止就直接执行
                    {                            //txt = sr.ReadToEnd()程序就在等待输入,而且又无法输入,直接掐住无法继续运行
                        proc.Kill();
                    }
                    string txt = sr.ReadToEnd();
                    sr.Close();
                    if (recordLog)
                        Trace.WriteLine(txt);
                    return txt;
                }
            }
            catch (Exception ex)
            {
                Trace.WriteLine(ex);
                return ex.Message;
            }
        }

大神代码源自帖子:

       

另有一种格局通过用ipconfig来获得:

private void GetIP()  
    {  
        Process cmd = new Process();  
        cmd.StartInfo.FileName = "ipconfig.exe";//设置程序名   
        cmd.StartInfo.Arguments = "/all";  //参数   
 //重定向标准输出   
        cmd.StartInfo.RedirectStandardOutput = true;  
        cmd.StartInfo.RedirectStandardInput = true;  
        cmd.StartInfo.UseShellExecute = false;  
        cmd.StartInfo.CreateNoWindow = true;//不显示窗口(控制台程序是黑屏)   
 //cmd.StartInfo.WindowStyle = ProcessWindowStyle.Hidden;//暂时不明白什么意思   
        /* 
 收集一下 有备无患 
        关于:ProcessWindowStyle.Hidden隐藏后如何再显示? 
        hwndWin32Host = Win32Native.FindWindow(null, win32Exinfo.windowsName); 
        Win32Native.ShowWindow(hwndWin32Host, 1);     //先FindWindow找到窗口后再ShowWindow 
        */  
        cmd.Start();  
        string info = cmd.StandardOutput.ReadToEnd();  
        cmd.WaitForExit();  
        cmd.Close();  
        textBox1.AppendText(info);  
    }

图片 1

此时将在本身出手看什么截取了。可参看上边大神怎么样用正则表明式来合营。

搜了一天,竟然没找到一段合适的代码来收获机器中具有网卡的ip,掩码和播音地址,大多数皆以用socket,可是socket日常重回的要不正是内网地址,要不正是公网地址,不可见找到全部地方,真的太难熬了,决定本身通过ifconfig或ipconfig的回来新闻,一步步地过滤了。这一次的代码首要使用了正则表达式和subprocess模块,而且为了合作全体平台(win,linux和mac),也利用了platform来判定系统项目,不说太多,代码如下:

相关文章