判断程序是否运行在虚拟机里 收藏


//判读程序是否运行在虚拟机里

#include <windows.h>

#include <stdio.h>

// IsInsideVPC's exception filter

DWORD __forceinline IsInsideVPC_exceptionFilter(LPEXCEPTION_POINTERS ep)

{

PCONTEXT ctx = ep->ContextRecord;

ctx->Ebx = -1; // Not running VPC

ctx->Eip += 4; // skip past the "call VPC" opcodes

return EXCEPTION_CONTINUE_EXECUTION;

// we can safely resume execution since we skipped faulty instruction

}



// High level language friendly version of IsInsideVPC()

bool IsInsideVPC()

{

bool rc = false;

__try

{

_asm push ebx

_asm mov ebx, 0 // It will stay ZERO if VPC is running

_asm mov eax, 1 // VPC function number



// call VPC

_asm __emit 0Fh

_asm __emit 3Fh

_asm __emit 07h

_asm __emit 0Bh

_asm test ebx, ebx

_asm setz [rc]

_asm pop ebx

}

// The except block shouldn't get triggered if VPC is running!!

__except(IsInsideVPC_exceptionFilter(GetExceptionInformation()))

{

}



return rc;

}



bool IsInsideVMWare()

{

bool rc = true;



__try

{

__asm

{

push edx

push ecx

push ebx







mov eax, 'VMXh'

mov ebx, 0 // any value but not the MAGIC value

mov ecx, 10 // get VMWare version

mov edx, 'VX' // port number







in eax, dx // read port

// on return EAX returns the VERSION

cmp ebx, 'VMXh' // is it a reply from VMWare?

setz [rc] // set return value







pop ebx

pop ecx

pop edx

}

}

__except(EXCEPTION_EXECUTE_HANDLER)

{

rc = false;

}



return rc;

}



int main()

{

if (IsInsideVPC()) printf("I am in a VPC/n");

else if (IsInsideVMWare()) printf("I am in a VMWare/n");

else printf("I am in a real world/n");

return 0;

}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值