Chinaunix首页 | 论坛 | 博客
  • 博客访问: 579692
  • 博文数量: 192
  • 博客积分: 3780
  • 博客等级: 中校
  • 技术积分: 1487
  • 用 户 组: 普通用户
  • 注册时间: 2010-08-26 10:11
文章存档

2012年(6)

2011年(160)

2010年(26)

分类: Java

2012-02-13 16:00:11

前言
在ItFunz上的一个软软推荐贴子里看到一个一键锁屏软件--lock now free. 感觉还不错,就是用了一段后, 每次用软件锁屏后, 再打开都显示软件设置界面. 在网上找原因, 有人说是因为免费版的原因, 但又找不到已付费版. 因此就想试着把它破了.

不懂java,也从未接触过android程序. 好在C风格的语言差别也不是很大,又在网上搜一些adroid程序开发的文章,对android程序的结构有了个大概的了解. 没想到最后竟然在连Hello World都不会写的情况下破解成功......

破解后的apk: 有需要的直接拿去用吧

-----------------------------------------------------------
欲善其事,先利其器, 先说一下要用到的的软件:
1. dex2jar:
2. jd-gui:
3. apktool:
4.apk签名工具: (原工具从itfunz论坛下载,里面带一些和apk签名无关的东西,体积太大)

/**********************************************/
apk文件其实是个压缩吧,用7zip之类的解压软件可以直接打开.

如图所示,解压后,有两个文件夹,三个文件.
META-INF文件夹里保存的是程序的签.android的程序用签名来保证程序的完整性, 我们需要在修改后用签名工具重新签名.
res文件夹里是资源文件, 图片啊什么都在这里, 汉化基本上也在是这里修改.
classes.dex, 这个是今天的主角, 我们要做的就是反编译这个文件,修改后,再重新编译.

///////////////////////////////////////////////////////////////////////////
总体思路:
首先,我们要用dex2jar把classes.dex反编译成jar文件, 然后用jd-gui打开反编译成出的jar文件, 找出需要修改的地方. 最后用apktool反编译整个apk包, 修改刚才在jd-gui中找出的修改点, 再用apktool重新编译, 编译后用签名工具签名,就可以安装了.

开始破解:
1. 先把apk解压, 把classes.dex复制到dex2jar的文件夹中(我懒得到路径才这么干 的^^)
2. 打开命令行, 进行dex2jar文件夹. 输入下面的命令把反编译生成jar文件:
dex2jar.bat classes.dex
完成后, 文件夹中会多出一个classes.dex.dex2jar.jar的文件.
(想省事的话,也可以把classes.dex拖动到dex2jar.bat上,效果是一样的,我就是这么干的,就是如果出错了,看不到错误)

3. 用jd-gui打开反编译出来的classes.dex.dex2jar.jar. (全是图形界面,不多说了)

通过分析,可以发现,图中的代码就是用来判断是否显示设置界面的. (adroid程序里,Activity就类似窗口的概念)
程序比较installDate和当前时间,如果当前时间大于installDate,就显示窗口. 如果你去看installDate的初始化代码,会发现它的值是文件修改时间加上604800000, 这个604800000正好是一星期的毫秒数, 这也解释了为什么直到一星期后才开始显示设置界面.

程序分析完了,下面开始修改.

4. 把apk文件(lock.apk)复制到apktool所在文件夹中. (....同样是懒得打路径)
5. 打开命令行, 进行apktool文件夹. 输入下面的命令把反编译apk文件:
apktool.bat d lock.apk lock
这条命令的意思是把lock.apk反编译并输出到Lock文件中. 完成后, 会多出一个lock文件夹.

6.打开新生成的lock文件夹. 会看到里面有个smali文件夹, 里面放的就是反编译出为的中间代码.
用文本编辑器打开smali\jp\hamachi\android\locknow\app\LNDummyActivity.smali文件, 里面全是类似汇编的中间代码(Dalvik opcodes).
之前已经分析过代码, 所以直奔我们要修改的地方:

图中的代码和我们在jd-gui中看到的代码相对应, 只要把if-gez v3, :cond_0 改成 goto :cond_0就行了, 不论什么情况,都转到cond_0. 当然也可以把前面的取时间啊,决断啊, 还有后面显示窗口的代码都删掉, 我就是这么干的.
(PS: 仔细读一下这些代码,你会发现程序流程和jd-gui中看到并非完全相同)

7. 修改已经完成了,接着,输入下面的命令,重新编译生成apk文件.:
apktool.bat b -f lock lockNew.apk
这个命令的意思是把Lock文件夹的内容build成lockNew.apk, -f是强制重新编译, 不加这个参数也可以. 命令完成后会在apktool的文件夹中生成lockNew.apk

8. 最后只要把lockNew.apk用签名工具重新签名就可以安装了. 这个也是完全的UI操作,非常简单,就不说了


由于本人对android很不熟悉,不足之处请多指教, 如果有不明白也可以留言,大家一起探讨.

转载请注明原文地址:
阅读(1190) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~