首页
社区
课程
招聘
OUT 指令在劲舞的HS中的躲避[已经解决]
发表于: 2007-12-21 08:19 18795

OUT 指令在劲舞的HS中的躲避[已经解决]

2007-12-21 08:19
18795
劲舞3.2版的时候 HS版本为 4.3.0.21
对于IO读写的驱动 他屏蔽了宏调用 WRITE_PORT_UCHAR
于是我用 out指令 嵌入汇编搞定
                  _asm
                  {
                          push eax
                          mov  al,OutBuff64
                          out  0x64,al
                          pop  eax
                  }
但劲舞升级到3.25以后 HS版本为 4.3.0.39
 发现 out指令也被检测到了 郁闷中
为了防止是内存特征
我对该指令 前后加了花指令 加了vmp1.6 
可惜调用时 过一段时间仍然被游戏检测到
实在无语,请各位大大们指点迷津

[注意]APP应用上架合规检测服务,协助应用顺利上架!

收藏
免费 0
支持
分享
最新回复 (45)
雪    币: 193
活跃值: (26)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
2
我在想 OUT 指令所操作的端口数据 应该属于bios上的 物理内存
有没有一种方法  不需要调用out来写io端口数据呢?
2007-12-21 08:23
0
雪    币: 223
活跃值: (70)
能力值: ( LV6,RANK:90 )
在线值:
发帖
回帖
粉丝
3
VM VM VM
2007-12-21 08:48
0
雪    币: 325
活跃值: (97)
能力值: ( LV13,RANK:530 )
在线值:
发帖
回帖
粉丝
4
强烈要求LZ共享 你的正版VMP 1.6
2007-12-21 12:04
0
雪    币: 193
活跃值: (26)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
5
.........VMP1.6 我还没捂热呢

下午又换了几种写法  

                 mov  al,OutBuff64
                          mov  BYTE PTR DS:[ESI],al
                          mov  dx,0x64
                          OUTSB
等都不成  intel指令都快要被用光了  难道是hs监视了 I/O数据
2007-12-21 18:12
0
雪    币: 331
活跃值: (56)
能力值: ( LV13,RANK:410 )
在线值:
发帖
回帖
粉丝
6
真搞不懂为啥Au刷分的漏洞不管,非要和模拟键盘的较劲。
喷嚏真顽强。
2007-12-21 19:50
0
雪    币: 193
活跃值: (26)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
7
哎  上次搞的刷20E的他也没封 单单就是封键盘  恼火中!

连 in out 都不放过
2007-12-21 22:07
0
雪    币: 331
活跃值: (56)
能力值: ( LV13,RANK:410 )
在线值:
发帖
回帖
粉丝
8
有狼狈为奸的嫌疑
2007-12-22 11:05
0
雪    币: 124
活跃值: (70)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
9
我是冲vmp 1.6来的
2007-12-22 16:08
0
雪    币: 427
活跃值: (412)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
10
检测指令就弱智了,肯定不是如此了。模拟按键还是给用硬件编程器比较好。USB,这就是专业外挂了。无法检测。呵呵
2007-12-22 19:06
0
雪    币: 193
活跃值: (26)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
11
调试发现 劲舞竟然用了CPU IO Debug  汗  完蛋了,这个是最底层的键盘拦截方式   难道真的要外接可编程硬件?
2007-12-22 22:51
0
雪    币: 331
活跃值: (56)
能力值: ( LV13,RANK:410 )
在线值:
发帖
回帖
粉丝
12
啥叫CPU IO DEBUG?
2007-12-22 23:19
0
雪    币: 193
活跃值: (26)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
13
具体我也说不上来
这个是一个 通过BIOS 调试寄存器 来获取按键的驱动  这种方式来获取按键 就算有nP保护的QQ 键盘照样能拦截到 更不多网银,支付宝之类了
应该属于最底层的截获键盘的方法  我就怕劲舞也是类似原理

/* inp.c
*
*
* - Global Specific I/O Address Space Trap -
*
*
* http://chpie.org
*
*
*
* 2007. 2 : first build.
*
*/
#include <ntddk.h>
#include "inp.h"

// Function prototypes
VOID DrvUnload(IN PDRIVER_OBJECT);
NTSTATUS DriverEntry(IN PDRIVER_OBJECT, IN PUNICODE_STRING);
NTSTATUS IoDeviceControl(IN PDEVICE_OBJECT, IN PIRP);
NTSTATUS IoReadWrite(IN PDEVICE_OBJECT, IN PIRP);
NTSTATUS IoDispatch(IN PDEVICE_OBJECT, IN PIRP);
void Initialization(VOID (*FunctionPointer)(IN PKDPC, IN PVOID, IN PVOID, IN PVOID));
void MPInitializationThread(IN PKDPC, IN PVOID, IN PVOID, IN PVOID);
void MPDisabledDebugRegisters(IN PKDPC, IN PVOID, IN PVOID, IN PVOID);
void MPDisabledThread(IN PKDPC, IN PVOID, IN PVOID, IN PVOID);
void BreakpointSetup(void);
void HandlerSetup(void);
volatile void NewHandler(void);

/*
*
* Structures
*
*/
#ifdef ALLOC_PRAGMA
#pragma alloc_text(INIT, DriverEntry)
#pragma alloc_text(NONPAGED, NewHandler)
#pragma alloc_text(PAGE, DrvUnload)
#pragma alloc_text(PAGE, IoDeviceControl)
#pragma alloc_text(PAGE, IoReadWrite)
#pragma alloc_text(PAGE, IoDispatch)
#pragma alloc_text(PAGE, Initialization)
#pragma alloc_text(PAGE, MPInitializationThread)
#pragma alloc_text(PAGE, BreakpointSetup)
#pragma alloc_text(PAGE, HandlerSetup)
#endif

#define NT_DEVICE_NAME L"\\Device\\INP" // device name and symbolic link name
#define DOS_DEVICE_NAME L"\\DosDevices\\INP"

#define IOCTL_REQUEST_DATA CTL_CODE(FILE_DEVICE_UNKNOWN, 0x800, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_REGISTER_EVENT CTL_CODE(FILE_DEVICE_UNKNOWN, 0x802, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_STOP_DEBUG_REGISTER CTL_CODE(FILE_DEVICE_UNKNOWN, 0x803, METHOD_BUFFERED, FILE_ANY_ACCESS)

#define EXIT_SIGNAL 0x1
#define CR4_DE_BIT 0x8
#define DR7_BP0_ENABLE_BIT 0xE0002
#define DR7_GENERAL_DETECTION_BIT 0x2000
#define DR7_INIT_IMAGE 0x00000400

/*
*
*
* Global Variables.
*
*/
PULONG OldHandler; // Old Handler's Pointer of INT#1

// Multi-processor
long allProcessorDone;
unsigned char * Packet; //Must referenced with KeGetCurrentProcessorNumber() !!!

// communication
PKEVENT pEvent = NULL;
UCHAR data[2];

/*
*
* Codes
*
*/

volatile _declspec( naked ) void NewHandler(void) // - Non-Paged
{
//
// - Interrupt 1 Handler -
//
// offset | contains
// ---------+-----------------------------
// ebp + 10 : EFLAGS Context
// ebp + 8 : CS Context
// ebp + 4 : EIP Context
// ebp : old-aged ebp
// ebp - 4 : DR_6 Frame
// ebp - 8 : KeGetCurrentProcessorNumber
//
#define LOCAL_STACK_VALUE 0x8
_asm
{
push ebp
mov ebp, esp
sub esp, LOCAL_STACK_VALUE

pushad
push fs
push ds
push es

mov eax, 0x00000030
mov fs, ax
mov eax, 0x00000023
mov ds, ax
mov es, ax

mov eax, dr6
mov dword ptr [ebp - 4], eax

call KeGetCurrentProcessorNumber
mov dword ptr [ebp - 8], eax

// Check EXIT PACKET
mov eax, Packet // ref Packet[KeGetCurrentProcessorNumber()]
add eax, dword ptr [ebp - 8]
cmp [eax], EXIT_SIGNAL
je Exit_Command_Raised

mov eax, dword ptr [ebp - 4]

// Check General Detection Raised
btr eax, 13 // General-Detection Bit in the DR6
jc General_Detection_Raised

// Check Break-point condition #0 Raised
btr eax, 0
jc Break_Point_0_Trap

jmp Exit_Process

Exit_Command_Raised:
mov dword ptr [ebp - 4], eax // clear dr6's BD Flag(bit offset 13)
add dword ptr [ebp + 4], 0x3 // eip_image + 3
jmp Exit_on_Raise

General_Detection_Raised:
mov dword ptr [ebp - 4], eax // clear dr6's BD Flag(bit offset 13)
add dword ptr [ebp + 4], 0x3 // eip_image + 3
jmp Exit_Process

Break_Point_0_Trap:
mov dword ptr [ebp - 4], eax // clear dr6's B0 Flag(bit offset 0)

//
// Filtering PS/2 mouse signal
//
in al, 0x64
cmp al, 0x14
jne Exit_Process

//
// BP0_Keyboard_Raised:
//
// :: Dispatch Keyboard data transmission.
//
//
// Pseudo code
//
// if (KeyboardType == PS/2 Compatible)
// Parse Opcode (0xEC, 0xED is 1byte, 0xE4, 0xE5 is 2byte align)
// if Opcode == 'IN' Class
// data[0] = AL image in the stack
// KeSetEvent(pEvent)
// else
// // It is 'OUT' class opcode
//
mov data[1], al
//BP0_Input_Opcode_Check:
mov ecx, dword ptr [ebp + 4]
dec ecx
mov bl, byte ptr [ecx]
cmp bl, 0xEC
je BP0_Send_Packet_To_App
cmp bl, 0xED
je BP0_Send_Packet_To_App

//BP0_Input_Opcode_Check_Next:
dec ecx
mov bl, byte ptr [ecx]
cmp bl, 0xE4
je BP0_Send_Packet_To_App
cmp bl, 0xE5
jne Exit_process

BP0_Send_Packet_To_App:
xor ecx, ecx
mov ecx, dword ptr [ebp - LOCAL_STACK_VALUE - 4] // Eax(pushad) in the stack
mov data[0], cl
cmp pEvent, 0
je BP0_Packet_not_requested
push 0 // Wait
push 0 // Increment
mov eax, pEvent
push eax
call ds:KeSetEvent

jmp Exit_Process // debug

BP0_Packet_not_requested:

jmp Exit_Process


Exit_Process:
mov eax, dword ptr [ebp - 4]
mov dr6, eax
mov eax, dr7
or eax, DR7_GENERAL_DETECTION_BIT // Re-enable General Detection
mov dr7, eax

Exit_on_Raise:
pop es
pop ds
pop fs
popad
add esp, LOCAL_STACK_VALUE
pop ebp
iretd
}
}

void Initialization(VOID (*FunctionPointer)(IN PKDPC, IN PVOID, IN PVOID, IN PVOID))
{
/*
*
* Multi-Processor Consideration ::
*
* Each processor has it's own IDT and Debug registers.
*
*/
CCHAR i;
long currentProcessor;
PKDPC pkDpc;
KIRQL oldIrql, currentIrql;

currentIrql = KeGetCurrentIrql();

if (currentIrql < DISPATCH_LEVEL)
KeRaiseIrql(DISPATCH_LEVEL, &oldIrql);

InterlockedAnd(&allProcessorDone, 0);

pkDpc = (PKDPC)ExAllocatePool(NonPagedPool, KeNumberProcessors * sizeof(KDPC));

if (!pkDpc)
{
DbgPrint("Insufficient Resource error\n");
return;
}

currentProcessor = KeGetCurrentProcessorNumber();

for (i = 0; i < KeNumberProcessors; i++)
{
KeInitializeDpc(&pkDpc,
FunctionPointer,
NULL);
KeSetTargetProcessorDpc(&pkDpc, i);
KeInsertQueueDpc(&pkDpc, NULL, NULL);
}

// wait for all of the processor's hooking initialization.
while(InterlockedCompareExchange(&allProcessorDone, KeNumberProcessors - 1, KeNumberProcessors - 1) != KeNumberProcessors - 1)
{
_asm pause;
}

if (currentIrql < DISPATCH_LEVEL)
KeLowerIrql(oldIrql);

if (pkDpc)
{
ExFreePool(pkDpc);
pkDpc = NULL;
}
}

void MPInitializationThread(IN PKDPC Dpc, IN PVOID DeferredContext, IN PVOID SystemArgument1, IN PVOID SystemArgument2)
{
HandlerSetup();
_asm cli;
BreakpointSetup();
_asm sti;

InterlockedIncrement(&allProcessorDone);
DbgPrint("allProcessorDone :: %x\n", allProcessorDone);
}

void MPDisabledThread(IN PKDPC Dpc, IN PVOID DeferredContext, IN PVOID SystemArgument1, IN PVOID SystemArgument2)
{
unsigned long i = KeGetCurrentProcessorNumber();
unsigned char buffer[6];
unsigned int * IdtrBaseAddress = (unsigned int *)&buffer[2]; // Idtr->Base
PIdtEntry_t IdtEntry;

_asm sidt buffer;
IdtEntry=(PIdtEntry_t)*IdtrBaseAddress; // Get a base address of idt

_asm cli;
IdtEntry[1].OffsetLow=(unsigned short)OldHandler;
IdtEntry[1].OffsetHigh=(unsigned short)((unsigned int)OldHandler>>16);
IdtEntry[1].Dpl = 0x3;
_asm sti;

InterlockedIncrement(&allProcessorDone);
}

void MPDisabledDebugRegisters(IN PKDPC Dpc, IN PVOID DeferredContext, IN PVOID SystemArgument1, IN PVOID SystemArgument2)
{
unsigned long i = KeGetCurrentProcessorNumber();

Packet = EXIT_SIGNAL;

_asm mov eax, dr7; // touch Trap!!!
_asm mov eax, dr7;

_asm
{
xor eax, eax
mov dr0, eax
mov eax, DR7_INIT_IMAGE // Double check
mov dr7, eax
mov eax, dr6
btr eax, 13
btr eax, 0
mov dr6, eax
}

InterlockedIncrement(&allProcessorDone);
}

void BreakpointSetup(void)
{
_asm
{
push eax

_emit 0x0f // mov eax, cr4(0F20E0)
_emit 0x20
_emit 0xe0
or eax, CR4_DE_BIT // Enable Debug Extension
_emit 0x0f // mov cr4, eax(0F22E0)
_emit 0x22
_emit 0xe0

mov eax, 0x60 // 0x60 Port
mov dr0, eax

mov eax, DR7_INIT_IMAGE
or eax, DR7_BP0_ENABLE_BIT // Enable Hardware Breakpoint 0
or eax, DR7_GENERAL_DETECTION_BIT // Enable General Detection
mov dr7, eax

pop eax
}
}

void HandlerSetup()
{
unsigned long i = KeGetCurrentProcessorNumber();
unsigned char buffer[6];
unsigned int * IdtrBaseAddress = (unsigned int *)&buffer[2]; // Idtr->Base
PIdtEntry_t IdtEntry;

_asm sidt buffer;
IdtEntry=(PIdtEntry_t)*IdtrBaseAddress; // Get a base address of idt

OldHandler = ((unsigned int)IdtEntry[1].OffsetHigh<<16U)|
(IdtEntry[1].OffsetLow);

IdtEntry[1].Dpl = 0x0; // adjust DPL

_asm nop;
_asm nop;
_asm nop;

_asm cli;
IdtEntry[1].OffsetLow=(unsigned short)NewHandler;
IdtEntry[1].OffsetHigh=(unsigned short)((unsigned int)NewHandler>>16);
_asm sti;
}

/*
*
* Driver Template
*
*/

VOID DrvUnload(IN PDRIVER_OBJECT pDriverObject)
{
PDEVICE_OBJECT pDeviceObject;
UNICODE_STRING uniWin32NameString;

Initialization(MPDisabledDebugRegisters);
Initialization(MPDisabledThread);

if (Packet)
ExFreePool(Packet);

if (OldHandler)
ExFreePool(OldHandler);

if (pEvent)
{
ObDereferenceObject(pEvent); // delete event reference
pEvent = NULL;
}

pDeviceObject = pDriverObject->DeviceObject;

RtlInitUnicodeString( &uniWin32NameString, DOS_DEVICE_NAME );
IoDeleteSymbolicLink( &uniWin32NameString );
IoDeleteDevice( pDriverObject->DeviceObject );
}

NTSTATUS DriverEntry(IN PDRIVER_OBJECT pDriverObject, IN PUNICODE_STRING RegistryPath)
{
PDEVICE_OBJECT pDeviceObject = NULL;
NTSTATUS ntStatus;
UNICODE_STRING uniNtNameString, uniWin32NameString;
int i;

RtlInitUnicodeString( &uniNtNameString, NT_DEVICE_NAME );
ntStatus = IoCreateDevice (
pDriverObject,
0, // DeviceExtensionSize
&uniNtNameString,
FILE_DEVICE_UNKNOWN, //
0, // No standard device characteristics
FALSE, // not exclusive device
&pDeviceObject
);
if( !NT_SUCCESS(ntStatus) )
{
return ntStatus;
}

// create dispatch points for create/open, close, unload
pDriverObject->DriverUnload = DrvUnload;

RtlInitUnicodeString( &uniWin32NameString, DOS_DEVICE_NAME );
ntStatus = IoCreateSymbolicLink( &uniWin32NameString, &uniNtNameString );
if (!NT_SUCCESS(ntStatus))
{
IoDeleteDevice( pDriverObject->DeviceObject );
}

for( i = 0; i < IRP_MJ_MAXIMUM_FUNCTION; i++ )
pDriverObject->MajorFunction = IoDispatch;

pDriverObject->MajorFunction[IRP_MJ_READ] =
pDriverObject->MajorFunction[IRP_MJ_WRITE] = IoReadWrite;
pDriverObject->MajorFunction[IRP_MJ_DEVICE_CONTROL] = IoDeviceControl;

i = KeNumberProcessors * sizeof(unsigned char);

Packet = (unsigned char * )ExAllocatePool(NonPagedPool, i); // Init exit packet
RtlZeroMemory(Packet, i);

i = KeNumberProcessors * sizeof(PULONG);

OldHandler = (PULONG)ExAllocatePool(NonPagedPool, i);
RtlZeroMemory(OldHandler, i);
///// /////
// //
// Start!!! //
// //
///// /////
Initialization(MPInitializationThread);

return STATUS_SUCCESS;
} //DriverEntry

NTSTATUS IoDispatch(IN PDEVICE_OBJECT pDeviceObject, IN PIRP pIrp)
{
NTSTATUS iStatus = STATUS_SUCCESS;

pIrp->IoStatus.Status = iStatus;
pIrp->IoStatus.Information = 0;
IoCompleteRequest( pIrp, IO_NO_INCREMENT );
return iStatus;
}

NTSTATUS IoDeviceControl(IN PDEVICE_OBJECT pDeviceObject, IN PIRP pIrp)
{
NTSTATUS iStatus = STATUS_SUCCESS;
PIO_STACK_LOCATION pStack;
ULONG iTransfered = 0;

HANDLE hEvent;

pStack = IoGetCurrentIrpStackLocation(pIrp);

switch( pStack->Parameters.DeviceIoControl.IoControlCode)
{
case IOCTL_REGISTER_EVENT:
hEvent = * (PHANDLE) pIrp->AssociatedIrp.SystemBuffer;
iStatus = ObReferenceObjectByHandle(hEvent, EVENT_MODIFY_STATE, *ExEventObjectType, pIrp->RequestorMode, (PVOID *)&pEvent, NULL);
break;

case IOCTL_REQUEST_DATA:
memcpy( (void *)pIrp->AssociatedIrp.SystemBuffer, (const void *)data, sizeof(char [2]));
iTransfered = sizeof(char [2]);
break;

default:
iStatus = STATUS_INVALID_PARAMETER;
break;
}

pIrp->IoStatus.Status = iStatus;
pIrp->IoStatus.Information = iTransfered;
IoCompleteRequest(pIrp, IO_NO_INCREMENT);

return iStatus;
}

NTSTATUS IoReadWrite(IN PDEVICE_OBJECT pDeviceObject, IN PIRP pIrp)
{
NTSTATUS iStatus = STATUS_SUCCESS;
PIO_STACK_LOCATION pStack;
ULONG iTransfered = 0;

pStack = IoGetCurrentIrpStackLocation(pIrp);

pIrp->IoStatus.Status = iStatus;
pIrp->IoStatus.Information = iTransfered;
IoCompleteRequest(pIrp, IO_NO_INCREMENT);

return iStatus;
}

2007-12-23 00:53
0
雪    币: 223
活跃值: (70)
能力值: ( LV6,RANK:90 )
在线值:
发帖
回帖
粉丝
14
自己做个usb的按键加个上位
2007-12-23 10:00
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
15
【求助】这个软件如何才能绕过网络验证,是通达信全能LEVEL2版,我搞了好多天了,因初学技术菜,希望高手指点一下小弟,感激涕零...   为什么我不能上传附件啊?这个是官方下载地址

http://www.tdx.com.cn/products/autoup/client/new_zszq_fastjy.exe
2007-12-23 10:25
0
雪    币: 193
活跃值: (26)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
16
豪无头绪与进展 ,愿意奉送vmp1.6正版换取突破劲舞的反IO读写按键  无奈中^^^
2007-12-24 04:52
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
17
继续努力吧!
2007-12-24 11:35
0
雪    币: 331
活跃值: (56)
能力值: ( LV13,RANK:410 )
在线值:
发帖
回帖
粉丝
18
真的能送正版VMP?
2007-12-24 12:09
0
雪    币: 193
活跃值: (26)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
19
真的哦!正版VMP
2007-12-24 13:39
0
雪    币: 124
活跃值: (70)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
20
破的方法换正版vmp亏大了,不换
2007-12-24 15:22
0
雪    币: 87
活跃值: (47)
能力值: ( LV12,RANK:250 )
在线值:
发帖
回帖
粉丝
21
vmp%u597D%u50CF%u4E0D%u8D35%u554A
2007-12-24 18:29
0
雪    币: 87
活跃值: (47)
能力值: ( LV12,RANK:250 )
在线值:
发帖
回帖
粉丝
22
vmp好像不贵啊
2007-12-24 18:31
0
雪    币: 193
活跃值: (26)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
23
大哥 你有钱  我是好不容易搞到的
他的钱  够我在学校吃半年的
2007-12-25 16:32
0
雪    币: 223
活跃值: (70)
能力值: ( LV6,RANK:90 )
在线值:
发帖
回帖
粉丝
24
1200左右吧,吃半年有点太忽悠了,现在学生一月600算少的了
2007-12-26 10:18
0
雪    币: 184
活跃值: (65)
能力值: ( LV6,RANK:90 )
在线值:
发帖
回帖
粉丝
25
搞外挂的还会买不起VMP?
2007-12-26 20:20
0
游客
登录 | 注册 方可回帖
返回
// // 统计代码