-
-
[旧帖]
[邀请码已发][求助]非API检测操作系统版本信息
0.00雪花
-
发表于:
2009-7-14 14:09
1625
-
[旧帖] [邀请码已发][求助]非API检测操作系统版本信息
0.00雪花
在PEB结构中存放着操作系统版本信息的函数,
ULONG OSMajorVersion; // A4h 偏移地址a4h显示操作系统主版本号
ULONG OSMinorVersion; // A8h 偏移地址a8h显示操作系统子版本号
通过读取OSMajorVersion和OSMinorVersion的数据能够确定操作系统的版本。
FS段寄存器指向当前的TEB结构,在TEB偏移0x30处是PEB指针,通过这个指针可以取得存放在PEB中的信息。
不同的操作系统,版本信息的存放的位置是不同的,其中
2000 0X0500
XP 0X0501
2003 0X0502
VISTA 0X0600
这样根据这些信息我们可以通过不调用API函数来获取操作系统的版本信息。
实现代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | int a=0,b=0,i=0,j=0;
_asm
{
pushad
mov ebx,fs:[0x18] ; get self pointer from TEB
mov eax,fs:[0x30] ; get pointer to PEB / database
mov ebx,[eax+0A8h] ; get OSMinorVersion
mov eax,[eax+0A4h] ; get OSMajorVersion
mov j,ebx
mov i,eax
popad
}
if ((i==5)&&(j==0))
{
AfxMessageBox( "系统版本为 Windows 200" ,MB_OK);
}
else if ((i==5)&&(j==1))
{
AfxMessageBox( "系统版本为 Windows Xp" ,MB_OK);
}
else if ((i==5)&&(j==2))
{
AfxMessageBox( "系统版本为 Windows 200" ,MB_OK);
}
else if ((i==6)&&(j==0))
{
AfxMessageBox( "系统版本为 WindowsVista" ,MB_OK);
}
|
这样我们就实现了不调用windowsAPI函数,但是却知道操作系统的版本信息。原理很简单,
http://bbs.pediy.com/showthread.php?threadid=11681这个帖子里说得很明白,只不过这个帖子里面的是汇编代码,
我用VC写了一下,效果还挺不错的,请大家多多指教。
再次感谢moonife,看雪学院真的是个高手聚集的地方,希望今后能学到更多的知识!
[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课