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');
    }
}

 

 

出处:https://www.cnblogs.com/MaxWoods/archive/2008/03/11/1100666.html

转载于:https://www.cnblogs.com/mq0036/p/10399835.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 获取机器码 API VC是指获取计算机硬件信息的一种接口。机器码是计算机硬件的唯一标识,可以用于软件的许可认证、设备管理等应用场景。 通过机器码 API VC,我们可以获取计算机的硬件信息,例如CPU型号、主板型号、硬盘序列号等。这些信息可以用于唯一标识一台计算机,实现设备的识别和管理。 获取机器码的方式有多种,可以通过调用系统API,访问硬件信息的接口,或者使用第三方库来获取。在实际开发中,我们可以根据具体需求选择适合的获取机器码的方式。 使用机器码 API VC,可以实现软件的许可认证。我们可以根据用户的机器码生成一个唯一的许可证文件,将该文件授权给用户,从而实现软件的合法使用。在用户每次打开软件时,我们可以通过验证机器码和许可证文件的匹配来判断软件的合法性。 此外,机器码 API VC还可以用于设备管理。通过获取机器码,我们可以对计算机进行标识和分类,方便进行管理。例如,我们可以根据机器码识别某个设备,然后对该设备进行监控、维修等操作。 综上所述,获取机器码 API VC是一种用于获取计算机硬件信息的接口,可以用于软件许可认证和设备管理。它能够帮助我们实现对计算机进行唯一标识和管理的目的。 ### 回答2: 获取机器码 API VC 是指通过 API 接口获取设备的唯一机器码机器码是一个用于标识设备的字符串,通常与设备的硬件信息和操作系统等相关。通过获取机器码,可以实现设备的身份认证、设备绑定和设备管理等功能。 VC 是 Virtual Channel 的缩写,意为虚拟通道。在网络通讯中,VC 可以代表一种通讯方式或通道,用于在客户端和服务器之间传输数据。通过 VC 的方式获取机器码可以在网络中方便地传递设备信息,提高系统的灵活性和可扩展性。 获取机器码 API VC 可以通过编程语言如 Java、Python 或 C# 等来实现。开发人员可以调用相应的 API 接口,从操作系统或硬件上获取设备信息,并生成机器码。这个机器码可以包含设备的硬件序列号、硬件地址、操作系统版本等信息,以确保唯一性。 通过获取机器码,可以实现一些常见的功能,例如: 1. 设备认证与授权:在系统中识别和验证设备,以确保设备的合法性,只允许授权设备使用系统功能。 2. 设备绑定:将机器码与用户账号进行绑定,确保用户只能在绑定的设备上登录和使用系统。 3. 设备管理与追踪:通过机器码可以对设备进行管理和追踪,包括设备状态监控、设备远程控制和设备数据分析等。 总之,获取机器码 API VC 是一种通过 API 接口获取设备唯一标识的方法。它可以用于设备认证、设备绑定和设备管理等功能,提高系统的安全性和可操作性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值