首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > .NET > VB Dotnet >

取硬盘序列号,该怎么解决

2013-03-19 
取硬盘序列号最近遇到一个很严重的问题,实在搞不定了,希望能有达人帮忙一下实际上网上很多这方面的问题,可

取硬盘序列号
最近遇到一个很严重的问题,实在搞不定了,希望能有达人帮忙一下

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

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


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


[解决办法]
给你一个比较全的,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'); 





[解决办法]
学习了,收藏.取硬盘序列号,该怎么解决
[解决办法]
很有意思的程序,记下了

热点排行