吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 25360|回复: 41
收起左侧

[原创] 对XX电子教室4.0的分析及编程处理

  [复制链接]
霖韵嫣然 发表于 2016-10-6 19:26
本帖最后由 zjh16529 于 2019-6-6 18:23 编辑

    前记
    这仅仅是本人无聊至极做出的分析,至于编程,本人也只是小小菜鸟,如有不当请大牛指正,自当万分感激。
由于微机课总是被老师的一节课的长篇大论占用完,所以感到心中不服,特此找来了这个软件来把玩,看看能不能写出一个内存补丁,实现屏幕广播窗口化并且不使鼠标键盘被锁定。然而出师不利,找个样本太困难,网上几乎没有,总算找到,在虚拟机里面安装的时候却蓝屏很多次……(解决方法:在系统盘根目录下找到BOOT.INIWindows XP)这个文件,而后修改第一条启动路径其中的参数noexecuteexecute)。我安装了两个虚拟机,一个安装学生端一个安装教师端,为了能够互相通信,使用了桥接网络的方式。

载入OD

这种软件,向来无壳,所以,直接拿来就分析。看一眼入口点,VC6特征如此明显,而加载的模块列表中也有MFC运行库,所以,明显的,MFC编写的程序。(如图)
模块.PNG
就算再不确定,查找一下所有模块间的调用,一眼看出……
寻找可操控点

这里,我直接去看了看教师端,发现设置里面有两个比较有趣的选项:(如图)
教师端设置.PNG

    这样,补丁的地方就显而易见了,它既然有这个选项,那么就说明,学生端在执行这条命令的时候,一定会有一个判断,对教师机是否选中这个选项的判断,所以,有了以下两种思路:
1.截获封包,自己处理其中的数据后再让学生端处理
2.直接修改学生端对应的反汇编代码,实现暴力**修改
由于本人才疏学浅,无法胜任第一项工作,只好去实现第二种思路,况且,第一种思路编出来的程序,难道不需要一直运行着?本人没做过,的确是不知道。
开始分析

    既然已经有了可以操控的地方,那么就应该开始分析。首先,要知道从何下端,在何修改。那么,在何处下端可以找到关键点?我认为消息循环处理处是一个不错的选择。寻找消息循环处理的代码有很多种方法,在此我只说适用于此软件的一种方法,那就是在置顶窗口的函数处下断。

    如何知道它使用了哪个置顶窗口的API?必须了解的是,这个软件窗口是本来不在前台的,要被设置到前台去,所以只能使用SetForegroundWindow,因此下断SetForegroundWindow,而后开始在教师端开始控制……

    果然断了下来,不过断下来的地方正和我意,居然是消息循环处理的地方……既然如此,那么开始劳动……单步走,看看要到哪个CALL里面去。(如图)
屏幕广播.PNG

跟了几步就到了,由于虚拟机没有安装中文输入法,英语水平也很差,于是乎使用了拼音,各位大神不要见怪。跟入CALL,通过不同设置的对比,得到两个关键跳转的地方。
004149EA75 04           jnzshort StudentE.004149F0
00414AC80F85 85000000   jnz StudentE.00414B53
这两个跳转如果全部NOP掉,那么就会变成窗口。那么,鼠标键盘锁在什么地方?继续向下走。(如图)
HOOK.PNG

得来全不费功夫,感谢作者,你起名起的太诗情画意了,完美!不过,这难道不是一个良好的编程习惯么?跟入,处理,将实现代码前的跳转全部处理掉,作出记录,然后,屏幕广播到此收工!
再在教师机处通过使用的功能,将其他的CALL的功能也摸清,结果如图。
Patchs.PNG
感觉整个人生都美妙了许多,不禁飘然若仙~~~
编程处理

如果是那些大牛们,自然是使用WIN32API啊、汇编啊、什么什么什么,然而,我等小菜,也就只能使用MFC来写了,因为……感觉界面实在难做本意又不是来做界面的至于易语言~感觉用起来太难受,想了想还是算了
于是乎,开始了无聊的编程~那么,关于编程我就不多做说明了,反正是一个内存补丁,没有多少技术含量。由于以前分析极域电子教室2.0的时候发现它HOOKOpenProcess这个API,所以……直接去调用Ntdll.dll里面的ZwOpenProcsss……貌似4.0版本没有HOOK……两个需要用到的结构体定义如下:

[C++] 纯文本查看 复制代码
typedef struct _CLIENT_ID
{
        HANDLE UniqueProcess;
        HANDLE UniqueThread;
}CLIENT_ID, *PCLIENT_ID;
typedef struct _OBJECT_ATTRIBUTES
{
        ULONG Length;
        HANDLE RootDirectory;
        PVOID ObjectName;
        ULONG Attritubes;
        PVOID SecurityDescriptor;
        PVOID SecurityQualityOfService;
}OBJECT_ATTRIBUTES, *POBJECT_ATTRIBUTES;

    接着,定义这个函数参数
[C++] 纯文本查看 复制代码
#define OUT
#define IN
typedef  DWORD(__stdcall *ZWOPENPROCESS)(
        OUT PHANDLE ProcessHandle,
        IN ACCESS_MASK DesiredAccess,
        IN POBJECT_ATTRIBUTES ObejectAttributes,
        IN PCLIENT_ID PClient_Id
        );

    再后来,在程序中的调用如下:
[C++] 纯文本查看 复制代码
bool MyOpenProcess(OUT PHANDLE ProcessHandle)
{
        HMODULE hModule = ::GetModuleHandle(L"ntdll.dll");
        if (hModule == NULL)
                return FALSE;
        ZWOPENPROCESS ZwOpenProcess = (ZWOPENPROCESS)GetProcAddress(hModule, "ZwOpenProcess");
        if (ZwOpenProcess == NULL)
                return FALSE;
        CLIENT_ID ClientID;
        ClientID.UniqueProcess = (HANDLE)PID; //UniqueProcess可以接受PID
        ClientID.UniqueThread = 0;
        OBJECT_ATTRIBUTES oa;
        oa.Length = sizeof(oa);
        oa.RootDirectory = 0;
        oa.ObjectName = 0;
        oa.Attritubes = 0;
        oa.SecurityDescriptor = 0;
        oa.SecurityQualityOfService = 0;
        NTSTATUS status = ZwOpenProcess(ProcessHandle, PROCESS_ALL_ACCESS, &oa, &ClientID);
        if (status == STATUS_INVALID_PARAMETER)
        {
                ::MessageBox(0, L"参数错误!请检查PID!", L"警告:",0);
                return FALSE;
        }
        return TRUE;
}

因为要获取PID,而枚举又太麻烦,于是做个编辑框让用户自己输入PID好了……还有一个需要注意的地方就是在写入补丁的时候,字节码反过来写……
例如:
int Data1 = 0x73EB;

后记

就是这么多了,我这样的小菜有错误在所难免,请各位大神指正
这个软件的破解我没有去研究,毕竟~我研究它干嘛~
补丁在WindowsXP上测试通过,在此我写死了地址,有ASLR的童鞋请自行处理

2017.4.23
以下链接失效,各位很抱歉,由于我也没有备份,所以无法补链

另外,我已将补丁开源,地址:https://yunpan.cn/cvZIyTVefngH8 访问密码 11fa
成品链接:https://yunpan.cn/cvZIJaDNPZgUg 访问密码 c833
极域4.0安装包链接:https://yunpan.cn/cvZIYdqXJ4kXs  访问密码 c01c
祝各位国庆愉快~



免费评分

参与人数 5威望 +1 热心值 +5 收起 理由
610100 + 1 谢谢@Thanks!大神,链接失效,能否更新为百度云链接?
szm + 1 学习一下
Sound + 1 + 1 已经处理,感谢您对吾爱破解论坛的支持!
987857149 + 1 不知道V6 2008豪华版能不能用
榻榻米 + 1 感谢作者,你起名起的太诗情画意了,完美!

查看全部评分

本帖被以下淘专辑推荐:

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

Bad丶Boy 发表于 2016-10-6 19:35
太厉害了,我学校也是用这个东西,其实不用这么麻烦,打开记事本,然后干关机的电源,他就弹出是否要保存记事本的内容,点取消就行了,就这么简单。
qazwsxlty 发表于 2017-4-4 12:46
咚小枫 发表于 2017-3-16 14:21
可以详细的讲一下方法2吗?谢谢大佬了。

虚拟桌面会有一定问题,现在已经不用了吧,因为被控制之后会锁键盘,所以一旦从自由桌面切换到被控制桌面就切不回去了。这样万一老师来一下切到了控制桌面,老师走了还得注销一下重新来,麻烦。如果想实现的话,百度有C#的虚拟桌面代码,拿过来用就行了。
现在我用的方法是江波ECR直接结束控制,红蜘蛛窗口化。因为拿不到江波6.0的安装包,所以到现在也没实现江波的窗口化。红蜘蛛窗口化我直接把他那个exe改了...不管教师机是否窗口化,学生机都是窗口化的...用的时候直接替换原exe,工具我也写了一个,但是太大,还是不发了,会被大神们拍死的...
zhangbaida 发表于 2016-10-6 19:33
头像被屏蔽
吾爱永远 发表于 2016-10-6 19:37
提示: 作者被禁止或删除 内容自动屏蔽
 楼主| 霖韵嫣然 发表于 2016-10-6 19:47
Bad丶Boy 发表于 2016-10-6 19:35
太厉害了,我学校也是用这个东西,其实不用这么麻烦,打开记事本,然后干关机的电源,他就弹出是否要保存记 ...

但是,有一个很现实的问题就是,你退出之后,教师机会显示你那台电脑黑屏......
Bad丶Boy 发表于 2016-10-6 20:02
霖韵嫣然 发表于 2016-10-6 19:47
但是,有一个很现实的问题就是,你退出之后,教师机会显示你那台电脑黑屏......

不会的不会的不会的
FantasyOwl 发表于 2016-10-6 20:21
PID怎么获取?
 楼主| 霖韵嫣然 发表于 2016-10-6 20:31

1.任务管理器
2.用API:
CreateToolhelp32Snapshot
Process32First
Process32Next
枚举。但是,一个问题是不能程序确定是否被改了名字,并且,这个程序运行的时候还没有窗口,被控制的时候才有那一个置顶窗口。
绯红花雨 发表于 2016-10-6 20:34
非常好的教程呀,感谢分享了
头像被屏蔽
Cy520 发表于 2016-10-6 21:06
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-11 16:55

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表