使用C#获取CPU及硬盘序列号的源代码

简介:

首先需添加对System.Management的引用。

view plaincopy to clipboardprint?
using System;    
using System.Runtime.InteropServices;    
using System.Management;    
  
namespace Hardware    
{    
    /// <summary>    
    /// HardwareInfo 的摘要说明。    
    /// </summary>    
    public class HardwareInfo    
    {    
        //取机器名     
        public string GetHostName()    
        {    
            return System.Net.Dns.GetHostName();    
        }    
        //取CPU编号    
        public String GetCpuID()    
        {    
            try    
            {    
                ManagementClass mc = new ManagementClass("Win32_Processor");    
                ManagementObjectCollection moc = mc.GetInstances();    
  
                String strCpuID = null;    
                foreach (ManagementObject mo in moc)    
                {    
                    strCpuID = mo.Properties["ProcessorId"].Value.ToString();    
                    break;    
                }    
                return strCpuID;    
            }    
            catch    
            {    
                return "";    
            }    
  
        }//end method    
  
        //取第一块硬盘编号    
        public String GetHardDiskID()    
        {    
            try    
            {    
                ManagementObjectSearcher searcher = new ManagementObjectSearcher("SELECT * FROM Win32_PhysicalMedia");    
                String strHardDiskID = null;    
                foreach (ManagementObject mo in searcher.Get())    
                {    
                    strHardDiskID = mo["SerialNumber"].ToString().Trim();    
                    break;    
                }    
                return strHardDiskID;    
            }    
            catch    
            {    
                return "";    
            }    
        }//end     
  
        public enum NCBCONST    
        {    
            NCBNAMSZ = 16,      /* absolute length of a net name         */    
            MAX_LANA = 254,      /* lana's in range 0 to MAX_LANA inclusive   */    
            NCBENUM = 0x37,      /* NCB ENUMERATE LANA NUMBERS            */    
            NRC_GOODRET = 0x00,      /* good return                              */    
            NCBRESET = 0x32,      /* NCB RESET                        */    
            NCBASTAT = 0x33,      /* NCB ADAPTER STATUS                  */    
            NUM_NAMEBUF = 30,      /* Number of NAME's BUFFER               */    
        }    
  
        [StructLayout(LayoutKind.Sequential)]    
        public struct ADAPTER_STATUS    
        {    
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = 6)]    
            public byte[] adapter_address;    
            public byte rev_major;    
            public byte reserved0;    
            public byte adapter_type;    
            public byte rev_minor;    
            public ushort duration;    
            public ushort frmr_recv;    
            public ushort frmr_xmit;    
            public ushort iframe_recv_err;    
            public ushort xmit_aborts;    
            public uint xmit_success;    
            public uint recv_success;    
            public ushort iframe_xmit_err;    
            public ushort recv_buff_unavail;    
            public ushort t1_timeouts;    
            public ushort ti_timeouts;    
            public uint reserved1;    
            public ushort free_ncbs;    
            public ushort max_cfg_ncbs;    
            public ushort max_ncbs;    
            public ushort xmit_buf_unavail;    
            public ushort max_dgram_size;    
            public ushort pending_sess;    
            public ushort max_cfg_sess;    
            public ushort max_sess;    
            public ushort max_sess_pkt_size;    
            public ushort name_count;    
        }    
  
        [StructLayout(LayoutKind.Sequential)]    
        public struct NAME_BUFFER    
        {    
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = (int)NCBCONST.NCBNAMSZ)]    
            public byte[] name;    
            public byte name_num;    
            public byte name_flags;    
        }    
  
        [StructLayout(LayoutKind.Sequential)]    
        public struct NCB    
        {    
            public byte ncb_command;    
            public byte ncb_retcode;    
            public byte ncb_lsn;    
            public byte ncb_num;    
            public IntPtr ncb_buffer;    
            public ushort ncb_length;    
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = (int)NCBCONST.NCBNAMSZ)]    
            public byte[] ncb_callname;    
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = (int)NCBCONST.NCBNAMSZ)]    
            public byte[] ncb_name;    
            public byte ncb_rto;    
            public byte ncb_sto;    
            public IntPtr ncb_post;    
            public byte ncb_lana_num;    
            public byte ncb_cmd_cplt;    
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = 10)]    
            public byte[] ncb_reserve;    
            public IntPtr ncb_event;    
        }    
  
        [StructLayout(LayoutKind.Sequential)]    
        public struct LANA_ENUM    
        {    
            public byte length;    
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = (int)NCBCONST.MAX_LANA)]    
            public byte[] lana;    
        }    
  
        [StructLayout(LayoutKind.Auto)]    
        public struct ASTAT    
        {    
            public ADAPTER_STATUS adapt;    
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = (int)NCBCONST.NUM_NAMEBUF)]    
            public NAME_BUFFER[] NameBuff;    
        }    
        public class Win32API    
        {    
            [DllImport("NETAPI32.DLL")]    
            public static extern char Netbios(ref NCB ncb);    
        }    
  
        public string GetMacAddress()    
        {    
            string addr = "";    
            try    
            {    
                int cb;    
                ASTAT adapter;    
                NCB Ncb = new NCB();    
                char uRetCode;    
                LANA_ENUM lenum;    
  
                Ncb.ncb_command = (byte)NCBCONST.NCBENUM;    
                cb = Marshal.SizeOf(typeof(LANA_ENUM));    
                Ncb.ncb_buffer = Marshal.AllocHGlobal(cb);    
                Ncb.ncb_length = (ushort)cb;    
                uRetCode = Win32API.Netbios(ref Ncb);    
                lenum = (LANA_ENUM)Marshal.PtrToStructure(Ncb.ncb_buffer, typeof(LANA_ENUM));    
                Marshal.FreeHGlobal(Ncb.ncb_buffer);    
                if (uRetCode != (short)NCBCONST.NRC_GOODRET)    
                    return "";    
  
                for (int i = 0; i < lenum.length; i++)    
                {    
                    Ncb.ncb_command = (byte)NCBCONST.NCBRESET;    
                    Ncb.ncb_lana_num = lenum.lana[i];    
                    uRetCode = Win32API.Netbios(ref Ncb);    
                    if (uRetCode != (short)NCBCONST.NRC_GOODRET)    
                        return "";    
  
                    Ncb.ncb_command = (byte)NCBCONST.NCBASTAT;    
                    Ncb.ncb_lana_num = lenum.lana[i];    
                    Ncb.ncb_callname[0] = (byte)'*';    
                    cb = Marshal.SizeOf(typeof(ADAPTER_STATUS)) + Marshal.SizeOf(typeof(NAME_BUFFER)) * (int)NCBCONST.NUM_NAMEBUF;    
                    Ncb.ncb_buffer = Marshal.AllocHGlobal(cb);    
                    Ncb.ncb_length = (ushort)cb;    
                    uRetCode = Win32API.Netbios(ref Ncb);    
                    adapter.adapt = (ADAPTER_STATUS)Marshal.PtrToStructure(Ncb.ncb_buffer, typeof(ADAPTER_STATUS));   
                    Marshal.FreeHGlobal(Ncb.ncb_buffer);    
  
                    if (uRetCode == (short)NCBCONST.NRC_GOODRET)    
                    {    
                        if (i > 0)    
                            addr += ":";    
                        addr = string.Format("{0,2:X}{1,2:X}{2,2:X}{3,2:X}{4,2:X}{5,2:X}",    
                         adapter.adapt.adapter_address[0],    
                         adapter.adapt.adapter_address[1],    
                         adapter.adapt.adapter_address[2],    
                         adapter.adapt.adapter_address[3],    
                         adapter.adapt.adapter_address[4],    
                         adapter.adapt.adapter_address[5]);    
                    }    
                }    
            }    
            catch    
            { }    
            return addr.Replace(' ', '0');    
        }    
    }    
}   
using System; 
using System.Runtime.InteropServices; 
using System.Management;

namespace Hardware 

    /// <summary> 
    /// HardwareInfo 的摘要说明。 
    /// </summary> 
    public class HardwareInfo 
    { 
        //取机器名  
        public string GetHostName() 
        { 
            return System.Net.Dns.GetHostName(); 
        } 
        //取CPU编号 
        public String GetCpuID() 
        { 
            try 
            { 
                ManagementClass mc = new ManagementClass("Win32_Processor"); 
                ManagementObjectCollection moc = mc.GetInstances();

                String strCpuID = null; 
                foreach (ManagementObject mo in moc) 
                { 
                    strCpuID = mo.Properties["ProcessorId"].Value.ToString(); 
                    break; 
                } 
                return strCpuID; 
            } 
            catch 
            { 
                return ""; 
            }

        }//end method

        //取第一块硬盘编号 
        public String GetHardDiskID() 
        { 
            try 
            { 
                ManagementObjectSearcher searcher = new ManagementObjectSearcher("SELECT * FROM Win32_PhysicalMedia"); 
                String strHardDiskID = null; 
                foreach (ManagementObject mo in searcher.Get()) 
                { 
                    strHardDiskID = mo["SerialNumber"].ToString().Trim(); 
                    break; 
                } 
                return strHardDiskID; 
            } 
            catch 
            { 
                return ""; 
            } 
        }//end 

        public enum NCBCONST 
        { 
            NCBNAMSZ = 16,      /* absolute length of a net name         */ 
            MAX_LANA = 254,      /* lana's in range 0 to MAX_LANA inclusive   */ 
            NCBENUM = 0x37,      /* NCB ENUMERATE LANA NUMBERS            */ 
            NRC_GOODRET = 0x00,      /* good return                              */ 
            NCBRESET = 0x32,      /* NCB RESET                        */ 
            NCBASTAT = 0x33,      /* NCB ADAPTER STATUS                  */ 
            NUM_NAMEBUF = 30,      /* Number of NAME's BUFFER               */ 
        }

        [StructLayout(LayoutKind.Sequential)] 
        public struct ADAPTER_STATUS 
        { 
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = 6)] 
            public byte[] adapter_address; 
            public byte rev_major; 
            public byte reserved0; 
            public byte adapter_type; 
            public byte rev_minor; 
            public ushort duration; 
            public ushort frmr_recv; 
            public ushort frmr_xmit; 
            public ushort iframe_recv_err; 
            public ushort xmit_aborts; 
            public uint xmit_success; 
            public uint recv_success; 
            public ushort iframe_xmit_err; 
            public ushort recv_buff_unavail; 
            public ushort t1_timeouts; 
            public ushort ti_timeouts; 
            public uint reserved1; 
            public ushort free_ncbs; 
            public ushort max_cfg_ncbs; 
            public ushort max_ncbs; 
            public ushort xmit_buf_unavail; 
            public ushort max_dgram_size; 
            public ushort pending_sess; 
            public ushort max_cfg_sess; 
            public ushort max_sess; 
            public ushort max_sess_pkt_size; 
            public ushort name_count; 
        }

        [StructLayout(LayoutKind.Sequential)] 
        public struct NAME_BUFFER 
        { 
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = (int)NCBCONST.NCBNAMSZ)] 
            public byte[] name; 
            public byte name_num; 
            public byte name_flags; 
        }

        [StructLayout(LayoutKind.Sequential)] 
        public struct NCB 
        { 
            public byte ncb_command; 
            public byte ncb_retcode; 
            public byte ncb_lsn; 
            public byte ncb_num; 
            public IntPtr ncb_buffer; 
            public ushort ncb_length; 
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = (int)NCBCONST.NCBNAMSZ)] 
            public byte[] ncb_callname; 
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = (int)NCBCONST.NCBNAMSZ)] 
            public byte[] ncb_name; 
            public byte ncb_rto; 
            public byte ncb_sto; 
            public IntPtr ncb_post; 
            public byte ncb_lana_num; 
            public byte ncb_cmd_cplt; 
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = 10)] 
            public byte[] ncb_reserve; 
            public IntPtr ncb_event; 
        }

        [StructLayout(LayoutKind.Sequential)] 
        public struct LANA_ENUM 
        { 
            public byte length; 
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = (int)NCBCONST.MAX_LANA)] 
            public byte[] lana; 
        }

        [StructLayout(LayoutKind.Auto)] 
        public struct ASTAT 
        { 
            public ADAPTER_STATUS adapt; 
            [MarshalAs(UnmanagedType.ByValArray, SizeConst = (int)NCBCONST.NUM_NAMEBUF)] 
            public NAME_BUFFER[] NameBuff; 
        } 
        public class Win32API 
        { 
            [DllImport("NETAPI32.DLL")] 
            public static extern char Netbios(ref NCB ncb); 
        }

        public string GetMacAddress() 
        { 
            string addr = ""; 
            try 
            { 
                int cb; 
                ASTAT adapter; 
                NCB Ncb = new NCB(); 
                char uRetCode; 
                LANA_ENUM lenum;

                Ncb.ncb_command = (byte)NCBCONST.NCBENUM; 
                cb = Marshal.SizeOf(typeof(LANA_ENUM)); 
                Ncb.ncb_buffer = Marshal.AllocHGlobal(cb); 
                Ncb.ncb_length = (ushort)cb; 
                uRetCode = Win32API.Netbios(ref Ncb); 
                lenum = (LANA_ENUM)Marshal.PtrToStructure(Ncb.ncb_buffer, typeof(LANA_ENUM)); 
                Marshal.FreeHGlobal(Ncb.ncb_buffer); 
                if (uRetCode != (short)NCBCONST.NRC_GOODRET) 
                    return "";

                for (int i = 0; i < lenum.length; i++) 
                { 
                    Ncb.ncb_command = (byte)NCBCONST.NCBRESET; 
                    Ncb.ncb_lana_num = lenum.lana[i]; 
                    uRetCode = Win32API.Netbios(ref Ncb); 
                    if (uRetCode != (short)NCBCONST.NRC_GOODRET) 
                        return "";

                    Ncb.ncb_command = (byte)NCBCONST.NCBASTAT; 
                    Ncb.ncb_lana_num = lenum.lana[i]; 
                    Ncb.ncb_callname[0] = (byte)'*'; 
                    cb = Marshal.SizeOf(typeof(ADAPTER_STATUS)) + Marshal.SizeOf(typeof(NAME_BUFFER)) * (int)NCBCONST.NUM_NAMEBUF; 
                    Ncb.ncb_buffer = Marshal.AllocHGlobal(cb); 
                    Ncb.ncb_length = (ushort)cb; 
                    uRetCode = Win32API.Netbios(ref Ncb); 
                    adapter.adapt = (ADAPTER_STATUS)Marshal.PtrToStructure(Ncb.ncb_buffer, typeof(ADAPTER_STATUS)); 
                    Marshal.FreeHGlobal(Ncb.ncb_buffer);

                    if (uRetCode == (short)NCBCONST.NRC_GOODRET) 
                    { 
                        if (i > 0) 
                            addr += ":"; 
                        addr = string.Format("{0,2:X}{1,2:X}{2,2:X}{3,2:X}{4,2:X}{5,2:X}", 
                         adapter.adapt.adapter_address[0], 
                         adapter.adapt.adapter_address[1], 
                         adapter.adapt.adapter_address[2], 
                         adapter.adapt.adapter_address[3], 
                         adapter.adapt.adapter_address[4], 
                         adapter.adapt.adapter_address[5]); 
                    } 
                } 
            } 
            catch 
            { } 
            return addr.Replace(' ', '0'); 
        } 
    } 

 

使用方法举例:

view plaincopy to clipboardprint?
//获取硬盘序列号    
Hardware.HardwareInfo hardwareInfo = new Hardware.HardwareInfo();    
string hardDiskID = hardwareInfo.GetHardDiskID();    
System.Console.WriteLine(hardDiskID);    
  
//获取CPU序列号    
string cpuID = hardwareInfo.GetCpuID();    
System.Console.WriteLine(cpuID);    
//获取硬盘序列号Hardware.HardwareInfo hardwareInfo = new Hardware.HardwareInfo();string hardDiskID = hardwareInfo.GetHardDiskID();System.Console.WriteLine(hardDiskID);//获取CPU序列号string cpuID = hardwareInfo.GetCpuID();System.Console.WriteLine(cpuID); 


本文转载自CSDN博客,http://blog.csdn.net/songkexin/archive/2009/12/01/4916602.aspx


作者:破  狼 
出处:http://www.cnblogs.com/whitewolf/ 
本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。该文章也同时发布在我的独立博客中-个人独立博客博客园--破狼51CTO--破狼。http://www.cnblogs.com/whitewolf/archive/2009/12/11/1622256.html

相关文章
|
5月前
|
API C++ Windows
C/C++ 实现获取硬盘序列号
获取硬盘的序列号、型号和固件版本号,此类功能通常用于做硬盘绑定或硬件验证操作,通过使用`Windows API`的`DeviceIoControl`函数与物理硬盘驱动程序进行通信,发送`ATA`命令来获取硬盘的信息。
160 0
C/C++ 实现获取硬盘序列号
|
4月前
将休眠镜像文件hiberfil.sys移动到D盘,可以减少C盘好几个G的空间占用
将休眠镜像文件hiberfil.sys移动到D盘,可以减少C盘好几个G的空间占用
|
Linux
Linux:磁盘情况查询+磁盘情况的工作使用指令(内含使用实例)
Linux:磁盘情况查询+磁盘情况的工作使用指令(内含使用实例)
132 0
Linux:磁盘情况查询+磁盘情况的工作使用指令(内含使用实例)
|
缓存 监控 网络协议
Linux:常用性能检查命令(内存、CPU 、网络、磁盘、Java应用)
Linux:常用性能检查命令(内存、CPU 、网络、磁盘、Java应用)
843 0
Linux:常用性能检查命令(内存、CPU 、网络、磁盘、Java应用)
|
Windows
在 Windows 安装期间将 MBR 磁盘转换为 GPT 磁盘
在 Windows 安装期间将 MBR 磁盘转换为 GPT 磁盘 版权声明:本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。欢迎转载、使用、重新发布,但务必保留文章署名吕毅(包含链接:http://blog.csdn.net/wpwalter/),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。
1411 0
|
C# 数据安全/隐私保护
C#/VB.NET 获取电脑属性(硬盘ID、硬盘容量、Cpu序列号、MAC地址、系统类型)
原文:C#/VB.NET 获取电脑属性(硬盘ID、硬盘容量、Cpu序列号、MAC地址、系统类型) 在开发过程中,经常需要获取电脑的一些属性,如获取硬盘ID/CPU序列号/MAC地址作为来加密字符串。 1、硬盘 在我查看网上一些文档时,发现很多人对硬盘序列号很模糊~ 什么叫硬盘序列号?指的是作为一个硬盘的标识;但是有时候发现,同事的电脑硬盘序列号有重复的。
1444 0

热门文章

最新文章