取硬盘序列号

lvlvlvlylyly 2013-03-16 04:38:09
最近遇到一个很严重的问题,实在搞不定了,希望能有达人帮忙一下

实际上网上很多这方面的问题,可惜很多人并没有实际操作过,以为拿到个代码,一运行,能得到一串数字就是序列号,大多数其实都是假的,是,是在你的机器上没问题,可一旦换个机器...

我曾经遇到过最厉害的,就是连换了五台,有三台是一样的.这样的东西怎能作为机器码..


现在我的问题就是搞不定win7,我想找个朋友帮忙一下,能否给我介绍一个免费的能取到win7硬盘序列号的dll.....谢谢了,....我也是姑且一试,...一夜了.....

...全文
183 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
小虾米zheng 2013-04-28
  • 打赏
  • 举报
回复
引用 1 楼 gxingmin 的回复:
给你一个比较全的,cpu、硬盘、网卡序列号 其中硬盘的有两个,一个是获取厂家出厂序列号,这是唯一的,你试一下 c#代码,你用工具转下vb.net的吧
using System; 
using System.Runtime.InteropServices; 
using System.Management; 

namespace Common
{ 
	/// <summary> 
	/// Hardware_Mac 的摘要说明。 
	/// </summary> 
	internal class clsHardInfo 
	{ 
		//取CPU编号 
		internal 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 

		internal string GetDiskID()
		{
			try
			{
				//获取硬盘ID 
				String HDid = "";
				ManagementClass mc = new ManagementClass("Win32_DiskDrive");
				ManagementObjectCollection moc = mc.GetInstances();
				foreach (ManagementObject mo in moc)
				{
					HDid = (string)mo.Properties["Model"].Value;
				}
				moc = null;
				mc = null;
				return HDid;
			}
			catch
			{
				return "";
			}
			finally
			{
			}

		}


		//取第一块硬盘编号 
		internal 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(Exception ex)
			{ 
				return ""; 
			} 
		}//end 

		internal 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)] 
			internal struct ADAPTER_STATUS 
		{ 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=6)] 
			internal byte[] adapter_address; 
			internal byte rev_major; 
			internal byte reserved0; 
			internal byte adapter_type; 
			internal byte rev_minor; 
			internal ushort duration; 
			internal ushort frmr_recv; 
			internal ushort frmr_xmit; 
			internal ushort iframe_recv_err; 
			internal ushort xmit_aborts; 
			internal uint xmit_success; 
			internal uint recv_success; 
			internal ushort iframe_xmit_err; 
			internal ushort recv_buff_unavail; 
			internal ushort t1_timeouts; 
			internal ushort ti_timeouts; 
			internal uint reserved1; 
			internal ushort free_ncbs; 
			internal ushort max_cfg_ncbs; 
			internal ushort max_ncbs; 
			internal ushort xmit_buf_unavail; 
			internal ushort max_dgram_size; 
			internal ushort pending_sess; 
			internal ushort max_cfg_sess; 
			internal ushort max_sess; 
			internal ushort max_sess_pkt_size; 
			internal ushort name_count; 
		} 

		[StructLayout(LayoutKind.Sequential)] 
			internal struct NAME_BUFFER 
		{ 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=(int)NCBCONST.NCBNAMSZ)] 
			internal byte[] name; 
			internal byte name_num; 
			internal byte name_flags; 
		} 

		[StructLayout(LayoutKind.Sequential)] 
			internal struct NCB 
		{ 
			internal byte ncb_command; 
			internal byte ncb_retcode; 
			internal byte ncb_lsn; 
			internal byte ncb_num; 
			internal IntPtr ncb_buffer; 
			internal ushort ncb_length; 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=(int)NCBCONST.NCBNAMSZ)] 
			internal byte[] ncb_callname; 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=(int)NCBCONST.NCBNAMSZ)] 
			internal byte[] ncb_name; 
			internal byte ncb_rto; 
			internal byte ncb_sto; 
			internal IntPtr ncb_post; 
			internal byte ncb_lana_num; 
			internal byte ncb_cmd_cplt; 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=10)] 
			internal byte[] ncb_reserve; 
			internal IntPtr ncb_event; 
		} 

		[StructLayout(LayoutKind.Sequential)] 
			internal struct LANA_ENUM 
		{ 
			internal byte length; 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=(int)NCBCONST.MAX_LANA)] 
			internal byte[] lana; 
		} 

		[StructLayout(LayoutKind.Auto)] 
			internal struct ASTAT 
		{ 
			internal ADAPTER_STATUS adapt; 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=(int)NCBCONST.NUM_NAMEBUF)] 
			internal NAME_BUFFER[] NameBuff; 
		} 
		internal class Win32API 
		{ 
			[DllImport("NETAPI32.DLL")] 
			internal static extern char Netbios(ref NCB ncb); 
		} 

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

	} 
} 
这个 代码我有几点疑问 ,希望能回答, 1,获取 CPU 编号 这个是有问题,型号一样的cpu 取出来的值 有可能 一样。 2,硬盘序列号的 代码 也是有问题的。- -只有固态硬盘时 有可能 取不到序列号,(而我遇到的问题是 调试时 取到的序列号 和 发布成网站之后 取到的 不一样,一直解决不了……) 3,mac地址如果 我手动 改掉了。这个 系统 取出来的 还会是 原值么?这个 也不能 作为 注册码来用吧??
申江渔夫 2013-03-16
  • 打赏
  • 举报
回复
很有意思的程序,记下了
苦苦的潜行者 2013-03-16
  • 打赏
  • 举报
回复
学习了,收藏.
gxingmin 2013-03-16
  • 打赏
  • 举报
回复
给你一个比较全的,cpu、硬盘、网卡序列号 其中硬盘的有两个,一个是获取厂家出厂序列号,这是唯一的,你试一下 c#代码,你用工具转下vb.net的吧
using System; 
using System.Runtime.InteropServices; 
using System.Management; 

namespace Common
{ 
	/// <summary> 
	/// Hardware_Mac 的摘要说明。 
	/// </summary> 
	internal class clsHardInfo 
	{ 
		//取CPU编号 
		internal 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 

		internal string GetDiskID()
		{
			try
			{
				//获取硬盘ID 
				String HDid = "";
				ManagementClass mc = new ManagementClass("Win32_DiskDrive");
				ManagementObjectCollection moc = mc.GetInstances();
				foreach (ManagementObject mo in moc)
				{
					HDid = (string)mo.Properties["Model"].Value;
				}
				moc = null;
				mc = null;
				return HDid;
			}
			catch
			{
				return "";
			}
			finally
			{
			}

		}


		//取第一块硬盘编号 
		internal 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(Exception ex)
			{ 
				return ""; 
			} 
		}//end 

		internal 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)] 
			internal struct ADAPTER_STATUS 
		{ 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=6)] 
			internal byte[] adapter_address; 
			internal byte rev_major; 
			internal byte reserved0; 
			internal byte adapter_type; 
			internal byte rev_minor; 
			internal ushort duration; 
			internal ushort frmr_recv; 
			internal ushort frmr_xmit; 
			internal ushort iframe_recv_err; 
			internal ushort xmit_aborts; 
			internal uint xmit_success; 
			internal uint recv_success; 
			internal ushort iframe_xmit_err; 
			internal ushort recv_buff_unavail; 
			internal ushort t1_timeouts; 
			internal ushort ti_timeouts; 
			internal uint reserved1; 
			internal ushort free_ncbs; 
			internal ushort max_cfg_ncbs; 
			internal ushort max_ncbs; 
			internal ushort xmit_buf_unavail; 
			internal ushort max_dgram_size; 
			internal ushort pending_sess; 
			internal ushort max_cfg_sess; 
			internal ushort max_sess; 
			internal ushort max_sess_pkt_size; 
			internal ushort name_count; 
		} 

		[StructLayout(LayoutKind.Sequential)] 
			internal struct NAME_BUFFER 
		{ 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=(int)NCBCONST.NCBNAMSZ)] 
			internal byte[] name; 
			internal byte name_num; 
			internal byte name_flags; 
		} 

		[StructLayout(LayoutKind.Sequential)] 
			internal struct NCB 
		{ 
			internal byte ncb_command; 
			internal byte ncb_retcode; 
			internal byte ncb_lsn; 
			internal byte ncb_num; 
			internal IntPtr ncb_buffer; 
			internal ushort ncb_length; 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=(int)NCBCONST.NCBNAMSZ)] 
			internal byte[] ncb_callname; 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=(int)NCBCONST.NCBNAMSZ)] 
			internal byte[] ncb_name; 
			internal byte ncb_rto; 
			internal byte ncb_sto; 
			internal IntPtr ncb_post; 
			internal byte ncb_lana_num; 
			internal byte ncb_cmd_cplt; 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=10)] 
			internal byte[] ncb_reserve; 
			internal IntPtr ncb_event; 
		} 

		[StructLayout(LayoutKind.Sequential)] 
			internal struct LANA_ENUM 
		{ 
			internal byte length; 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=(int)NCBCONST.MAX_LANA)] 
			internal byte[] lana; 
		} 

		[StructLayout(LayoutKind.Auto)] 
			internal struct ASTAT 
		{ 
			internal ADAPTER_STATUS adapt; 
			[MarshalAs(UnmanagedType.ByValArray, SizeConst=(int)NCBCONST.NUM_NAMEBUF)] 
			internal NAME_BUFFER[] NameBuff; 
		} 
		internal class Win32API 
		{ 
			[DllImport("NETAPI32.DLL")] 
			internal static extern char Netbios(ref NCB ncb); 
		} 

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

	} 
} 

16,555

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧