首页
社区
课程
招聘
[原创]Wing IDE 4.1 Windows CracK Log
发表于: 2012-3-30 15:25 13663

[原创]Wing IDE 4.1 Windows CracK Log

obaby 活跃值
20
2012-3-30 15:25
13663

Wing IDE 4.1 Windows Crack

前天在论坛上看到《Wing IDE 4.1.3-1 crack》这么一篇文章,文章中有提供一个附件。我手*点了一下下载了,并且把安装程序也下载了。但是安装之后用各种方法来替换文件,运行的时候还是会弹出试用期还剩九天的提示。
网上还有其他的破解方法,修改的是abstract.pyo这个文件。其实网上的这个方法把修改之后的代码再次解析出来应该是错误的。因为虽然修改的是检测剩余天数的地方。但是直接修改为跳转,应该是直接把整个校验代码的流程给打乱了,于是就会显示为missing。

这个是根据网上的方法修改后授权页面的信息(相关链接会以参考的形式在最后给出)。那么既然是修改注册校验流程,并且知道了修改的方法那么还是有办法进行完美处理的。这里把用到的方法流程再记录一下。
注册相关的处理代码都是在F:\Wing IDE 4.1\bin\2.5目录下的src.zip文件中。而我们要修改的两个文件是wingctl.pyo和abstract.pyo(文件位于process文件夹中)。

这两个文件都是编译之后的二进制文件,是没有办法直接看到python代码的,需要首先将二进制代码解析为字节码。以前我记得windows下也有反编译pyo和pyc文件的程序,但是叫什么忘了。也懒得去找了,直接使用linux下的unpyclib进行处理吧。从这里(http://sourceforge.net/projects/unpyc/files/UnPyc/UnPyc (v0.8.1)/unpyc_0.8.1_all.deb/download?use_mirror=nchc)下载unpyclib进行安装,如果上面的地址失效了大家就自己搜索吧。
安装之后所有的py脚本会安装到如下的目录中:

打开终端执行如下命令cd /usr/lib/UnPyc/unpyclib/切换到unpyclib目录下,执行sudo python application.py -d abstract.pyo > /home/obaby/桌面/abstract.txt 解析abstract.pyo文件并输出到桌面的abstract.txt文件中。

现在就可以用文本编辑器来查看解析后的字节码指令了。直接使用文本编辑器打开abstract.txt搜索Invalid license activation会定位到如下所示的代码位置:

具体代码如下:
code:
0000523E STR: 't\x00\x00d\x01\x00\x83\x01\x00|\x01\x00d\x02\x00<x6\x00t\x01\x00D].\x00}\x03\x00|\x01\x00i\x02\x00...' (2F 03 00 00 74 00 00 64 01 00 83 01...)

……省略部分代码……

000001BC 64 - LOAD_CONST 'Invalid license activation'
000001BF 83 - CALL_FUNCTION
000001C2 66 - BUILD_TUPLE
000001C5 53 - RETURN_VALUE
000001C6 6E - JUMP_FORWARD -> 000001CA
000001C9 01 - POP_TOP
000001CA 7C - LOAD_FAST 'self'
000001CD 69 - LOAD_ATTR '_GetTermDaysLeft'
000001D0 7C - LOAD_FAST 'lic'
000001D3 83 - CALL_FUNCTION
000001D6 7D - STORE_FAST 'daysleft'
000001D9 7C - LOAD_FAST 'daysleft'
000001DC 64 - LOAD_CONST -1
000001DF 6A - COMPARE_OP "=="
000001E2 6F - JUMP_IF_FALSE -> 000001F9
后面的字节码指令也不难理解,直接按照字面意思理解即可。那么要想程序试用期永不过期,只需要只需要将 000001E2 6F – JUMP_IF_FALSE -> 000001F9 一行跳转到过期的代码nop掉即可。
知道了如何修改,那么剩下的就比较简单了。通过计算偏移来定位二进制代码的位置。函数的起始地址为0000523E,相对偏移为000001E2,那么实际的二进制指令便宜也就是0000523E + 000001E2 =5420.用十六进制编辑器打开abstract.pyo。跳转到这个地址,代码如下:

通过计算可以知道指令的长度为3.那么要修改为nop就需要将6F 14 00全部用09填充掉。填充之后的效果如下图:

保存之后为了确保修改无误可以重新解析一下文件看下修改之后的代码是否已经nop掉了。重新解析之后的代码如下图所示:

到这里这个文件的修改就完成了,直接重新压缩回zip文件即可,但是单纯修改这个东西还是会弹出剩余天数的提示。
那么现在就来修改第二个文件wingctl.pyo。还是用上面的方法处理之后的代码如下所示:
00002880 STR: '\x88\x00\x00i\x00\x00o\x08\x00\x01d\x01\x00Sn\x01\x00\x01\x88\x00\x00i\x01\x00\x83\x00\x00}\x01\x00|\x01\x00d\x02...' (BE 01 00 00 88 00 00 69 00 00 6F 08...)
00000000 88 - LOAD_DEREF 'self'
00000003 69 - LOAD_ATTR '_fExpiringLicenseCheck'
00000006 6F - JUMP_IF_FALSE -> 00000011
00000009 01 - POP_TOP
0000000A 64 - LOAD_CONST None
0000000D 53 - RETURN_VALUE
0000000E 6E - JUMP_FORWARD -> 00000012
00000011 01 - POP_TOP
00000012 88 - LOAD_DEREF 'self'
00000015 69 - LOAD_ATTR '_GetTermDaysLeft'
原来的这个函数太长了,这里只显示前面一点点,其实这个就是弹出授权只剩九天的那个提示窗口。 如果去掉那些恼人的提示信息,只需要让程序在 0000000D 53 – RETURN_VALUE一行直接返回即可。那么唯一需要做的就是把上面的 00000006 6F – JUMP_IF_FALSE -> 00000011一行代码nop掉。而所有的代码应该都是三个字节的,定位到二进制文件中的对应的位置如下所示:

修改完成之后同样压缩回zip文件中。其实到现在这个东西的爆破已经非常简单了,只要过程分析清楚了,想怎么爆破都可以了。通过上面的方法修改之后就可以显示正常的授权信息。

通过上面的方法修改之后的二进制python文件同样可以用于linux系统下,但是从windows操作系统下压缩的放到linux系统下会导致wing无法正常启动,所以最好的办法是在linux系统下将文件重新压缩回压缩包中。授权效果如下:

并且检查更新是没有问题的:

不过除此之外应该还有其他的破解方法,这个大家就自由发挥吧。第一次搞python的破解,文章写的不好,大家不要介意撒。~

PDF版本下载:
Wing IDE 4 Crack.pdf

参考文章:
http://www.meiyear.com/wordpress/archives/277
http://sourceforge.net/projects/unpyc/


[招生]系统0day安全班,企业级设备固件漏洞挖掘,Linux平台漏洞挖掘!

上传的附件:
收藏
免费 6
支持
分享
最新回复 (6)
雪    币: 444
活跃值: (103)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
2
总算抢到沙发了。膜拜啊
2012-3-30 16:22
0
雪    币: 1708
活跃值: (586)
能力值: ( LV15,RANK:670 )
在线值:
发帖
回帖
粉丝
3
学习123456
2012-3-30 20:11
0
雪    币: 542
活跃值: (116)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
4
厉害啊厉害!!学习了!
2012-4-21 15:11
0
雪    币: 4560
活跃值: (1012)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
5
不错可惜俺对python不是很感冒
2012-4-21 16:04
0
雪    币: 37
活跃值: (25)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
6
正愁没法破解呢,哈哈 学习啦
2012-8-31 15:46
0
雪    币: 14983
活跃值: (5290)
能力值: ( LV15,RANK:880 )
在线值:
发帖
回帖
粉丝
7
这个帖子怎么还变成求助解答了?太奇怪了
2012-9-4 11:01
0
游客
登录 | 注册 方可回帖
返回
// // 统计代码