简介

在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来判断系统项目,不说太多,代码如下:

Author

发表评论

电子邮件地址不会被公开。 必填项已用*标注