使用c#获得cpu,硬盘的序列号

原创 2007年09月25日 10:30:00

using System;
using System.Runtime.InteropServices;
using  System.Management;
namespace Hardware
{
 /// <summary>
 /// Hardware_Mac 的摘要说明。
 /// </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');
  }

 }
}

 

 

C#获取硬盘、CPU、主板、网卡的序列号

转自:http://blog.sina.com.cn/s/blog_557d25460101hq9t.html 在很多情况下,你可能都需要得到微机的硬件信息。比如:你想给你的软件加锁...
  • threadroc
  • threadroc
  • 2016-06-05 22:26:58
  • 2669

C#如何获取CPU序列号,或者更多……

介绍有时候为了了解运行机器的情况,我们必须在C#中,为了要获取CPU序列号,必须添加引用 System.Management 。介绍有时候为了做一些加密的工作时,我们必须了解机器的CPU型号,硬盘编号...
  • allenle
  • allenle
  • 2007-08-24 17:54:00
  • 4614

C#获取CPU序列号,MAC地址,硬盘ID…

//1.cpu序列号2.mac序列号3.硬盘id //在给软件加序列号时这三个应该是最有用的,可以实现序列号和机器绑定,对保护软件很有好处. using System;  using Syst...
  • K346K346
  • K346K346
  • 2015-07-19 00:21:36
  • 4091

C# 获取CPU 硬盘 序列号 获取硬件信息 等等

  • 2010年04月28日 23:05
  • 50KB
  • 下载

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

首先需添加对System.Management的引用。using System; using System.Runtime.InteropServices; using System.Manageme...
  • songkexin
  • songkexin
  • 2009-12-01 19:45:00
  • 21009

C#_读取机器码_CPU序列号_生成注册码类

  • 2016年06月23日 21:37
  • 4KB
  • 下载

一分钟学会获取CPU序列号

        我再强调一遍,并不是所有的处理器都有序列号!Intel的文档告诉我们Pentium 4 系列的处理器不支持序列号!经过测试发现AMD的机器也没有,奇郁闷,看来这个Processor S...
  • colinchan
  • colinchan
  • 2007-03-30 11:38:00
  • 11481

<em>c</em>语言获取 <em>CPU序列号</em>(CPUID) 硬盘序列号 (vs2010工程)支持64位...

共67个 共<em>23</em>页 1 <em>2 3</em> 4 5 下一页 尾页 登录后才能评论 读取...<em>c</em>语言获取 <em>CPU序列号</em>(CPUID) 硬盘序列号 (vs2010工程)支持64位编译 立即下载...
  • 2018年04月07日 00:00

C#获取CPU序列号代码、硬盘ID、网卡硬件地址等类文件

using System; using System.Management; namespace GetIDs { /// /// 计算机信息类 /// ...
  • CLeopard
  • CLeopard
  • 2014-10-13 17:42:11
  • 3664

__cpuidex读取CPU序列号

__cpuidex读取CPU序列号
  • gdnh22a
  • gdnh22a
  • 2017-02-14 14:43:37
  • 2341
收藏助手
不良信息举报
您举报文章:使用c#获得cpu,硬盘的序列号
举报原因:
原因补充:

(最多只允许输入30个字)