• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C#教程 > C#获取机器码的方法详解(机器名,CPU编号,硬盘编号,网卡mac等)

C#获取机器码的方法详解(机器名,CPU编号,硬盘编号,网卡mac等)

作者:mn-soft.com 字体:[增加 减小] 来源:互联网 时间:2017-05-28

mn-soft.com 通过本文主要向大家介绍了c#泛型详解,c#网站开发案例详解,c#关键字详解,c#三层架构详解,c#基础与案例开发详解等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

本文实例讲述了C#获取机器码的方法。分享给大家供大家参考,具体如下:

using System.Runtime.InteropServices;
using System.Management;
using System;
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);
  }
  //取网卡mac
  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');
  }
}

</div>

更多关于C#相关内容感兴趣的读者可查看本站专题:《C#窗体操作技巧汇总》、《C#常见控件用法教程》、《WinForm控件用法总结》、《C#程序设计之线程使用技巧总结》、《C#操作Excel技巧总结》、《C#中XML文件操作技巧汇总》、《C#数据结构与算法教程》、《C#数组操作技巧总结》及《C#面向对象程序设计入门教程》

希望本文所述对大家C#程序设计有所帮助。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C#的泛型方法解析
  • C#给Excel添加水印实例详解
  • C#枚举类型和结构体详解
  • C#基础之泛型
  • C#调用Java方法实例详解
  • C#获取机器码的方法详解(机器名,CPU编号,硬盘编号,网卡mac等)
  • C#中数组Array,ArrayList,泛型List详细对比
  • C#泛型委托的用法实例分析
  • C#同步网络时间的方法实例详解
  • C#中的预处理器指令详解

相关文章

  • 2017-05-28C#简单的向量用法实例教程
  • 2017-05-28将DLL放入到资源中,运行时自动加载的小例子
  • 2017-05-28C#实现用于生成条形码的类
  • 2017-05-28C#中分部类和分部方法的应用
  • 2017-05-28C#与Java的MD5简单验证(实例代码)
  • 2017-05-28轻松学习C#的预定义数据类型
  • 2017-05-28C#通过WIN32 API实现嵌入程序窗体
  • 2017-05-28C#编程实现自定义热键的方法
  • 2017-05-28C#实现字体旋转的方法
  • 2017-05-28C# 中的动态创建组件(属性及事件)的实现思路及方法

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C#不同类型的成员变量(字段)的默认值介绍
    • c#利用Excel直接读取数据到DataGridView
    • C#实现TCP连接信息统计的方法
    • C#实现判断一个时间点是否位于给定时间区间的方法
    • c#文件下载示例的4种方法分享
    • c#检测usb设备拨插类库USBClassLibrary分享
    • c#读写App.config,ConfigurationManager.AppSettings 不生效的解决方法
    • C#遍历集合与移除元素的方法
    • 使用C#发送Http请求实现模拟登陆实例
    • C#后台创建控件并获取值的方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有