码迷,mamicode.com
首页 > 移动开发 > 详细

Android破解之Lic文件加密程序(首例)

时间:2015-07-13 20:35:59      阅读:530      评论:0      收藏:0      [点我收藏+]

标签:

我不会写Android,这是我第一个破解Android的例子,耗时接近一天,希望大神不要见笑!

本程序为商业软件,不便发布APK程序。

不要给我发消息,我不得回,有问题,直接回帖就可以了。

准备工作

在开始之前,要进行以下准备工作:

(1)安装JDK,至于版本,自己选择吧,目前我是用JDK1.6版,可以去官网下载安装,并进行环境配置;

(2)安装模拟器,APK软件要运行测试,需要环境,模拟器是个好东西,我用的是海马玩模拟器,不知道行不行;

(3)APK编辑器下载,现在我还是工具党,只能依靠工具,我用的是APK改之理,我并不知道为什么要取这么一个名字。

至于,这三个软件 ,哪个版本相互之间最搭配,现在我还不知道,只能在后面学习过程中总结发现。

限制测试

现在进入正题,在查看、编译APK之前,得让原版程序在模拟器上运行一下,一方面,可以检查apk文件是否有效,我有很多小伙伴经常拿着有问题的数据在那里测试,为了莫名的错误百度都用烂了;另一方面,可以看看软件到底有什么限制。下面以默认账户登陆,然后出现了"此硬件设备未授权!"的错误信息。其实,这个软件需要放置一个lic许可文件在根目录下,但我们没有这个lic许可文件……

技术分享

反编译程序

将apk程序载入APK改之理3.2版,出现以下错误,果断换了2.5版,就成功进行反编译了。

技术分享

注意,文件名不能有中文,不然,无法进行正常反编译。

技术分享

搜索关键

下面是主界面,左边目录树是项目的文件,中间上面是主要视图窗体,中间下面是日志窗口,右边是搜索面板。现在我得搜索一下我们的重要线索"此硬件设备未授权",在右边的搜索面板没有找到任何结果!陷入了僵局……,注意,这里的代码并不是JAVA代码,而是一种叫Smali的语言,不是那么好理解,因为跳转比较多,有点让人头痛!要想看懂并修改这些代码,其语法可参考文章末尾的链接。

技术分享

但后来发现,Smali中的字符串是Unicode编码,于是,复制了一段就可以转换成汉字。

技术分享

技术分享

后来发现,可以看到JAVA源代码,打开任意*.smali文件,在编辑工具栏,打开JAVA源码即可用;在这里面就可进行中文搜索了,现在找到了关键位置。

技术分享 技术分享

分析代码

由于打码非常麻烦,所以就不分析怎么具体修改Smali代码了,下面是JAVA源码,主要是判断i值,在Smali语法中,if-nez表示不等于0……,if-eqz表示等于0……

技术分享

编译程序

修改完毕后,保存,菜单栏"编译"-"编译生成",即可编译生成程序。

技术分享

如果出现签名不成功,菜单栏"工具"-"配置与选项",修改签名工具为jarsigner尝试。

技术分享

运行测试

在模拟器上安装测试使用,如果成功,再拿到平板上进行实地测试。当然,不要看这文章一下子就写出来,在模拟上的测试,不止一次两次的,多次尝试,总会成功!

技术分享

?

参考:

Smali语法学习与DEX文件详解:http://www.apkbus.com/android-181396-1-1.html

Android apk反编译基础:http://www.jb51.net/softjc/119036.html

apk反汇编之smali语法:http://bbs.pediy.com/showthread.php?p=1117963

Apk改之理(Apk IDE)使用常见问题:http://bbs.angeeks.com/thread-2617106-1-1.html

Android破解之Lic文件加密程序(首例)

标签:

原文地址:http://www.cnblogs.com/liweis/p/4643744.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!