C# 获取当前设备硬件信息
Posted Hansel.Wn
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C# 获取当前设备硬件信息相关的知识,希望对你有一定的参考价值。
需求描述
现在有这样一个需求:
我有A、B两台服务器,其中A是一个视频处理服务器,B是一个数据存储服务器。此时有一个视频需要先在A服务器上进行一系列处理后,再上传到B服务器上进行存储。
为了减少人工手动处理的工作量,A服务器需要主动向B发送数据,然后B服务器接收数据后进行存储,但是在这个过程中我不希望B服务器接收A服务器之外的其他端上传的数据,所以B在接收数据的时候就需要对数据的来源进行一个验证。
这里A服务器在上传数据时携带自身服务器的硬件信息,通过验证硬件信息的方法,能够确定数据来源是否是A服务器。
确定当前程序运行在那种平台上
IsOSPlatform 方法用于指示当前应用程序是否正在指定平台上运行:
public static bool IsOSPlatform (System.Runtime.InteropServices.OSPlatform osPlatform);
参数osPlatform表示一种操作系统平台:
value | Description |
---|---|
FreeBSD | 获取表示 FreeBSD 操作系统的对象 |
Linux | 获取表示 Linux 操作系统的对象 |
OSX | 获取表示 OSX 操作系统的对象 |
Windows | 获取表示 Windows 操作系统的对象 |
ManagementObjectSearcher类获取硬件信息
ManagementObjectSearcher
是一个构造函数,在使用之前需要引入命名空间using System Management
,这个构造函数接收一个字符串作为参数,这个字符串一般写作"select * from" + key
,这里key的值有多种:
ManagementObjectSearcher searcher = new ManagementObjectSearcher("select * from " + Key);
// 常用Key值
// 硬件
Win32_Processor, // CPU 处理器
Win32_PhysicalMemory, // 物理内存条
Win32_Keyboard, // 键盘
Win32_PointingDevice, // 点输入设备,包括鼠标。
Win32_FloppyDrive, // 软盘驱动器
Win32_DiskDrive, // 硬盘驱动器
Win32_CDROMDrive, // 光盘驱动器
Win32_BaseBoard, // 主板
Win32_Bios, // BIOS 芯片
Win32_ParallelPort, // 并口
Win32_SerialPort, // 串口
Win32_SerialPortConfiguration, // 串口配置
Win32_SoundDevice, // 多媒体设置,一般指声卡。
Win32_SystemSlot, // 主板插槽 (ISA & PCI & AGP)
Win32_USBController, // USB 控制器
Win32_NetworkAdapter, // 网络适配器
Win32_NetworkAdapterConfiguration, // 网络适配器设置
Win32_Printer, // 打印机
Win32_PrinterConfiguration, // 打印机设置
Win32_PrintJob, // 打印机任务
Win32_TCPIPPrinterPort, // 打印机端口
Win32_POTSModem, // MODEM
Win32_POTSModemToSerialPort, // MODEM 端口
Win32_DesktopMonitor, // 显示器
Win32_DisplayConfiguration, // 显卡
Win32_DisplayControllerConfiguration, // 显卡设置
Win32_VideoController, // 显卡细节。
Win32_VideoSettings, // 显卡支持的显示模式。
// 操作系统
Win32_TimeZone, // 时区
Win32_SystemDriver, // 驱动程序
Win32_DiskPartition, // 磁盘分区
Win32_LogicalDisk, // 逻辑磁盘
Win32_LogicalDiskToPartition, // 逻辑磁盘所在分区及始末位置。
Win32_LogicalMemoryConfiguration, // 逻辑内存配置
Win32_PageFile, // 系统页文件信息
Win32_PageFileSetting, // 页文件设置
Win32_BootConfiguration, // 系统启动配置
Win32_ComputerSystem, // 计算机信息简要
Win32_OperatingSystem, // 操作系统信息
Win32_StartupCommand, // 系统自动启动程序
Win32_Service, // 系统安装的服务
Win32_Group, // 系统管理组
Win32_GroupUser, // 系统组帐号
Win32_UserAccount, // 用户帐号
Win32_Process, // 系统进程
Win32_Thread, // 系统线程
Win32_Share, // 共享
Win32_NetworkClient, // 已安装的网络客户端
Win32_NetworkProtocol, // 已安装的网络协议
示例代码
获取CPU序列号
private string GetServerCode()
string code = "";
if (System.Runtime.InteropServices.RuntimeInformation.IsOSPlatform(System.Runtime.InteropServices.OSPlatform.Windows))
ManagementObjectSearcher searcher = new ManagementObjectSearcher("Select * From Win32_Processor");
foreach (ManagementObject mo in searcher.Get())
code = mo["ProcessorId"].ToString().Trim();
break;
else
code = ExecuteCommand("dmidecode -t Processor | grep ID | sort -u | awk -F':' 'print $2'");
Console.WriteLine("serverCode:" + code);
return (code ?? "").Replace(" ", "").Trim();
在上面获取CPU序列号的示例代码中,首先创建了一个ManagementObjectSearcher
对象,然后通过Get()
方法获得ManagementObjectCollection集合
,然后使用foreach方法遍历这个集合拿到ManagementObject
数据,通过managementObject[name]或ManagementObject.GetPropertyValue(name)
获得想要的属性。
不过在这之前我并不知道这个name的值具体填什么,这个时候只需要通过console打印一下就好了。
ManagementClass类解析和C#如何获取硬件的相关信息
在.NET的项目中,有时候需要获取计算机的硬件的相关信息,在C#语言中需要利用ManagementClass这个类来进行相关操作。
现在先来介绍一下ManagementClass类,首先看一下类的继承结构:
现在看一下MSDN对ManagementClass类的解释,对表示一个通用信息模型 (CIM) 管理类。 管理类是 WMI 类,如 Win32_LogicalDisk, ,该类型可表示一个磁盘驱动器,并 Win32_Process, ,它表示的进程 Notepad.exe 等。 此类的成员可以访问 WMI 数据,使用一个特定的 WMI 类路径。
一. 接下来我们来看一下ManagementClass类中一些较为常用的方法的源码:
1.GetInstances():此方法存在四个重载
下面提供一下GetInstances(EnumerationOptions options)重载版本的代码:
public ManagementObjectCollection GetInstances(EnumerationOptions options) { if ((null == Path) || (null == Path.Path) || (0 == Path.Path.Length)) throw new InvalidOperationException(); Initialize ( false ); IEnumWbemClassObject enumWbem = null; EnumerationOptions o = (null == options) ? new EnumerationOptions() : (EnumerationOptions)options.Clone(); o.EnsureLocatable = false; o.PrototypeOnly = false; SecurityHandler securityHandler = null; int status = (int)ManagementStatus.NoError; try { securityHandler = Scope.GetSecurityHandler(); status = scope.GetSecuredIWbemServicesHandler(Scope.GetIWbemServices() ).CreateInstanceEnum_(ClassName, o.Flags, o.GetContext(), ref enumWbem ); } finally { if (securityHandler != null) securityHandler.Reset(); } if (status < 0) { if ((status & 0xfffff000) == 0x80041000) ManagementException.ThrowWithExtendedInfo((ManagementStatus)status); else Marshal.ThrowExceptionForHR(status); } return new ManagementObjectCollection(Scope, o, enumWbem); }
2.Get():
下面提供一下Get()重载版本的代码:
public ManagementObjectCollection Get() { Initialize (); IEnumWbemClassObject ew = null; SecurityHandler securityHandler = scope.GetSecurityHandler(); EnumerationOptions enumOptions = (EnumerationOptions)options.Clone(); int status = (int)ManagementStatus.NoError; try { if ((query.GetType() == typeof(SelectQuery)) && (((SelectQuery)query).Condition == null) && (((SelectQuery)query).SelectedProperties == null) && (options.EnumerateDeep == true)) { enumOptions.EnsureLocatable = false; enumOptions.PrototypeOnly = false; if (((SelectQuery)query).IsSchemaQuery == false) { status = scope.GetSecuredIWbemServicesHandler( scope.GetIWbemServices() ).CreateInstanceEnum_( ((SelectQuery)query).ClassName, enumOptions.Flags, enumOptions.GetContext(), ref ew); } else { status = scope.GetSecuredIWbemServicesHandler(scope.GetIWbemServices() ).CreateClassEnum_(((SelectQuery)query).ClassName, enumOptions.Flags, enumOptions.GetContext(), ref ew ); } } else { enumOptions.EnumerateDeep = true; status = scope.GetSecuredIWbemServicesHandler(scope.GetIWbemServices() ).ExecQuery_( query.QueryLanguage, query.QueryString, enumOptions.Flags, enumOptions.GetContext(), ref ew ); } } catch (COMException e) { // ManagementException.ThrowWithExtendedInfo(e); } finally { securityHandler.Reset(); } if ((status & 0xfffff000) == 0x80041000) { ManagementException.ThrowWithExtendedInfo((ManagementStatus)status); } else if ((status & 0x80000000) != 0) { Marshal.ThrowExceptionForHR(status); } return new ManagementObjectCollection(scope, options, ew); }
3.GetSubclasses():此方法存在四个重载版本
下面提供一下GetSubclasses(EnumerationOptions options)重载版本的代码:
public ManagementObjectCollection GetSubclasses(EnumerationOptions options) { if (null == Path) throw new InvalidOperationException(); Initialize ( false ) ; IEnumWbemClassObject enumWbem = null; EnumerationOptions o = (null == options) ? new EnumerationOptions() : (EnumerationOptions)options.Clone(); o.EnsureLocatable = false; o.PrototypeOnly = false; SecurityHandler securityHandler = null; int status = (int)ManagementStatus.NoError; try { securityHandler = Scope.GetSecurityHandler(); status = scope.GetSecuredIWbemServicesHandler( Scope.GetIWbemServices() ).CreateClassEnum_(ClassName, o.Flags, o.GetContext(), ref enumWbem); } finally { if (securityHandler != null) securityHandler.Reset(); } if (status < 0) { if ((status & 0xfffff000) == 0x80041000) ManagementException.ThrowWithExtendedInfo((ManagementStatus)status); else Marshal.ThrowExceptionForHR(status); } return new ManagementObjectCollection(Scope, o, enumWbem); }
以上是对ManagementClass类的部分谁明,此类型的所有公共静态成员都是线程安全的。不保证所有实例成员都是线程安全的。
二.ManagementClass类的部分应用:
/// <summary> /// 获得CPU编号 /// </summary> /// <returns></returns> public string GetCpuid() { var cpuid = string.Empty; var mc = new ManagementClass("Win32_Processor"); var moc = mc.GetInstances(); foreach (var o in moc) { var mo = (ManagementObject) o; cpuid = mo.Properties["ProcessorId"].Value.ToString(); } return cpuid; } /// <summary> /// 获取硬盘序列号 /// </summary> /// <returns></returns> public string GetDiskSerialNumber() { //这种模式在插入一个U盘后可能会有不同的结果,如插入我的手机时 var hDid = string.Empty; var mc = new ManagementClass("Win32_DiskDrive"); var moc = mc.GetInstances(); foreach (var o in moc) { var mo = (ManagementObject) o; hDid = (string)mo.Properties["Model"].Value; //这名话解决有多个物理盘时产生的问题,只取第一个物理硬盘 break; } return hDid; } /// <summary> /// 获取网卡硬件地址 /// </summary> /// <returns></returns> public string GetMacAddress() { var mac = ""; var mc = new ManagementClass("Win32_NetworkAdapterConfiguration"); var moc = mc.GetInstances(); foreach (var o in moc) { var mo = (ManagementObject) o; if (!(bool) mo["IPEnabled"]) continue; mac = mo["MacAddress"].ToString(); break; } return mac; } /// <summary> /// 获取IP地址 /// </summary> /// <returns></returns> public string GetIpAddress() { var st = string.Empty; var mc = new ManagementClass("Win32_NetworkAdapterConfiguration"); var moc = mc.GetInstances(); foreach (var o in moc) { var mo = (ManagementObject) o; if (!(bool) mo["IPEnabled"]) continue; var ar = (Array)(mo.Properties["IpAddress"].Value); st = ar.GetValue(0).ToString(); break; } return st; } /// <summary> /// 操作系统的登录用户名 /// </summary> /// <returns></returns> public string GetUserName() { return Environment.UserName; } /// <summary> /// 获取计算机名 /// </summary> /// <returns></returns> public string GetComputerName() { return Environment.MachineName; } /// <summary> /// 操作系统类型 /// </summary> /// <returns></returns> public string GetSystemType() { var st = string.Empty; var mc = new ManagementClass("Win32_ComputerSystem"); var moc = mc.GetInstances(); foreach (var o in moc) { var mo = (ManagementObject) o; st = mo["SystemType"].ToString(); } return st; } /// <summary> /// 物理内存 /// </summary> /// <returns></returns> public string GetPhysicalMemory() { var st = string.Empty; var mc = new ManagementClass("Win32_ComputerSystem"); var moc = mc.GetInstances(); foreach (var o in moc) { var mo = (ManagementObject) o; st = mo["TotalPhysicalMemory"].ToString(); } return st; } /// <summary> /// 显卡PNPDeviceID /// </summary> /// <returns></returns> public string GetVideoPnpid() { var st = ""; var mos = new ManagementObjectSearcher("Select * from Win32_VideoController"); foreach (var o in mos.Get()) { var mo = (ManagementObject) o; st = mo["PNPDeviceID"].ToString(); } return st; } /// <summary> /// 声卡PNPDeviceID /// </summary> /// <returns></returns> public string GetSoundPnpid() { var st = string.Empty; var mos = new ManagementObjectSearcher("Select * from Win32_SoundDevice"); foreach (var o in mos.Get()) { var mo = (ManagementObject) o; st = mo["PNPDeviceID"].ToString(); } return st; } /// <summary> /// CPU版本信息 /// </summary> /// <returns></returns> public string GetCpuVersion() { var st = string.Empty; var mos = new ManagementObjectSearcher("Select * from Win32_Processor"); foreach (var o in mos.Get()) { var mo = (ManagementObject) o; st = mo["Version"].ToString(); } return st; } /// <summary> /// CPU名称信息 /// </summary> /// <returns></returns> public string GetCpuName() { var st = string.Empty; var driveId = new ManagementObjectSearcher("Select * from Win32_Processor"); foreach (var o in driveId.Get()) { var mo = (ManagementObject) o; st = mo["Name"].ToString(); } return st; } /// <summary> /// CPU制造厂商 /// </summary> /// <returns></returns> public string GetCpuManufacturer() { var st = string.Empty; var mos = new ManagementObjectSearcher("Select * from Win32_Processor"); foreach (var o in mos.Get()) { var mo = (ManagementObject) o; st = mo["Manufacturer"].ToString(); } return st; } /// <summary> /// 主板制造厂商 /// </summary> /// <returns></returns> public string GetBoardManufacturer() { var query = new SelectQuery("Select * from Win32_BaseBoard"); var mos = new ManagementObjectSearcher(query); var data = mos.Get().GetEnumerator(); data.MoveNext(); var board = data.Current; return board.GetPropertyValue("Manufacturer").ToString(); } /// <summary> /// 主板编号 /// </summary> /// <returns></returns> public string GetBoardId() { var st = string.Empty; var mos = new ManagementObjectSearcher("Select * from Win32_BaseBoard"); foreach (var o in mos.Get()) { var mo = (ManagementObject) o; st = mo["SerialNumber"].ToString(); } return st; } /// <summary> /// 主板型号 /// </summary> /// <returns></returns> public string GetBoardType() { var st = string.Empty; var mos = new ManagementObjectSearcher("Select * from Win32_BaseBoard"); foreach (var o in mos.Get()) { var mo = (ManagementObject) o; st = mo["Product"].ToString(); } return st; }
本文出自 “彭泽0902” 博客,请务必保留此出处http://pengze0902.blog.51cto.com/7693836/1863419
以上是关于C# 获取当前设备硬件信息的主要内容,如果未能解决你的问题,请参考以下文章
C#上位机专题06 - 串口助手开发(完善发送,支持中文,保存信息)