#include<string>
#include<cstdio>
using namespace std
int main()
{
system("ipconfig /all")//使用运行CMD.exe,并输入ipconfig /all,可得出本机所有物理地址信息(IP信息)
getchar()//获取记录信息
return 0
}
总的来说 FRAMEWORK 好像不提供这些功能,如果你想调用的话,就得C#内调 USR32.DLL 这些系统内部的DLL文件.下面是我以前复制来的,总的道理就是 调用USER32.DLL 然后用它里面的函数初始化C#结构,里面有各种硬件信息.
using System
using System.Collections.Generic
using System.Diagnostics
using System.Threading
using System.IO
using System.Text
using System.Management
using System.Runtime.InteropServices
namespace Lemony.SystemInfo
{
///
///
public class SystemInfo
{
private int m_ProcessorCount = 0 //CPU个数
private PerformanceCounter pcCpuLoad //CPU计数器
private long m_PhysicalMemory = 0 //物理内存
private const int GW_HWNDFIRST = 0
private const int GW_HWNDNEXT = 2
private const int GWL_STYLE = (-16)
private const int WS_VISIBLE = 268435456
private const int WS_BORDER = 8388608
#region AIP声明
[DllImport("IpHlpApi.dll")]
extern static public uint GetIfTable(byte[] pIfTable, ref uint pdwSize, bool bOrder)
[DllImport("User32")]
private extern static int GetWindow(int hWnd, int wCmd)
[DllImport("User32")]
private extern static int GetWindowLongA(int hWnd, int wIndx)
[DllImport("user32.dll")]
private static extern bool GetWindowText(int hWnd, StringBuilder title, int maxBufSize)
[DllImport("user32", CharSet = CharSet.Auto)]
private extern static int GetWindowTextLength(IntPtr hWnd)
#endregion
#region 构造函数
///
/// 构造函数,初始化计数器等
///
public SystemInfo()
{
//初始化CPU计数器
pcCpuLoad = new PerformanceCounter("Processor", "% Processor Time", "_Total")
pcCpuLoad.MachineName = "."
pcCpuLoad.NextValue()
//CPU个数
m_ProcessorCount = Environment.ProcessorCount
//获得物理内存
ManagementClass mc = new ManagementClass("Win32_ComputerSystem")
ManagementObjectCollection moc = mc.GetInstances()
foreach (ManagementObject mo in moc)
{
if (mo["TotalPhysicalMemory"] != null)
{
m_PhysicalMemory = long.Parse(mo["TotalPhysicalMemory"].ToString())
}
}
}
#endregion
#region CPU个数
///
/// 获取CPU个数
///
public int ProcessorCount
{
get
{
return m_ProcessorCount
}
}
#endregion
#region CPU占用率
///
/// 获取CPU占用率
///
public float CpuLoad
{
get
{
return pcCpuLoad.NextValue()
}
}
#endregion
#region 可用内存
///
/// 获取可用内存
///
public long MemoryAvailable
{
get
{
long availablebytes = 0
//ManagementObjectSearcher mos = new ManagementObjectSearcher("SELECT * FROM Win32_PerfRawData_PerfOS_Memory")
//foreach (ManagementObject mo in mos.Get())
//{
//availablebytes = long.Parse(mo["Availablebytes"].ToString())
//}
ManagementClass mos = new ManagementClass("Win32_OperatingSystem")
foreach (ManagementObject mo in mos.GetInstances())
{
if (mo["FreePhysicalMemory"] != null)
{
availablebytes = 1024 * long.Parse(mo["FreePhysicalMemory"].ToString())
}
}
return availablebytes
}
}
#endregion
#region 物理内存
///
/// 获取物理内存
///
public long PhysicalMemory
{
get
{
return m_PhysicalMemory
}
}
#endregion
#region 获得分区信息
///
/// 获取分区信息
///
public List GetLogicalDrives()
{
List drives = new List()
ManagementClass diskClass = new ManagementClass("Win32_LogicalDisk")
ManagementObjectCollection disks = diskClass.GetInstances()
foreach (ManagementObject disk in disks)
{
// DriveType.Fixed 为固定磁盘(硬盘)
if (int.Parse(disk["DriveType"].ToString()) == (int)DriveType.Fixed)
{
drives.Add(new DiskInfo(disk["Name"].ToString(), long.Parse(disk["Size"].ToString()), long.Parse(disk["FreeSpace"].ToString())))
}
}
return drives
}
///
/// 获取特定分区信息
///
/// 盘符
public List GetLogicalDrives(char DriverID)
{
List drives = new List()
WqlObjectQuery wmiquery = new WqlObjectQuery("SELECT * FROM Win32_LogicalDisk WHERE DeviceID = ’" + DriverID + ":’")
ManagementObjectSearcher wmifind = new ManagementObjectSearcher(wmiquery)
foreach (ManagementObject disk in wmifind.Get())
{
if (int.Parse(disk["DriveType"].ToString()) == (int)DriveType.Fixed)
{
drives.Add(new DiskInfo(disk["Name"].ToString(), long.Parse(disk["Size"].ToString()), long.Parse(disk["FreeSpace"].ToString())))
}
}
return drives
}
#endregion
#region 获得进程列表
///
/// 获得进程列表
///
public List GetProcessInfo()
{
List pInfo = new List()
Process[] processes = Process.GetProcesses()
foreach (Process instance in processes)
{
try
{
pInfo.Add(new ProcessInfo(instance.Id,
instance.ProcessName,
instance.TotalProcessorTime.TotalMilliseconds,
instance.WorkingSet64,
instance.MainModule.FileName))
}
catch { }
}
return pInfo
}
///
/// 获得特定进程信息
///
/// 进程名称
public List GetProcessInfo(string ProcessName)
{
List pInfo = new List()
Process[] processes = Process.GetProcessesByName(ProcessName)
foreach (Process instance in processes)
{
try
{
pInfo.Add(new ProcessInfo(instance.Id,
instance.ProcessName,
instance.TotalProcessorTime.TotalMilliseconds,
instance.WorkingSet64,
instance.MainModule.FileName))
}
catch { }
}
return pInfo
}
#endregion
#region 结束指定进程
///
/// 结束指定进程
///
/// 进程的 Process ID
public static void EndProcess(int pid)
{
try
{
Process process = Process.GetProcessById(pid)
process.Kill()
}
catch { }
}
#endregion
#region 查找所有应用程序标题
///
/// 查找所有应用程序标题
///
/// 应用程序标题范型
public static List FindAllApps(int Handle)
{
List Apps = new List()
int hwCurr
hwCurr = GetWindow(Handle, GW_HWNDFIRST)
while (hwCurr >0)
{
int IsTask = (WS_VISIBLE | WS_BORDER)
int lngStyle = GetWindowLongA(hwCurr, GWL_STYLE)
bool TaskWindow = ((lngStyle &IsTask) == IsTask)
if (TaskWindow)
{
int length = GetWindowTextLength(new IntPtr(hwCurr))
StringBuilder sb = new StringBuilder(2 * length + 1)
GetWindowText(hwCurr, sb, sb.Capacity)
string strTitle = sb.ToString()
if (!string.IsNullOrEmpty(strTitle))
{
Apps.Add(strTitle)
}
}
hwCurr = GetWindow(hwCurr, GW_HWNDNEXT)
}
return Apps
}
#endregion
}
}
MAC地址是2层的东西,过了3层路由器后源MAC与目的MAC就会跟着所经过的路由器地址改变,如果在客户端没有任何响应进程将MAC地址信息放在应用层,理论上你不可能获得。能非常容易的获得ip地址、mac地址跟主机名应该是蛮危险的事情。你要真想问,你可以去黑客论坛找找吧。。。欢迎分享,转载请注明来源:夏雨云
评论列表(0条)