摘自http://blog.csdn.net/yanzi1225627/article/details/48215549
对文章中的一些细节进行补充
**************
补充一些细节
apk解压后有多个 dex 文件时,无法对单个dex文件通过 dex2jar 生成 jar文件
解决方法:
直接调用dex2jar name.apk 可直接生成 这个多dex的apk文件对应的jar文件
*************
全部步骤完成 总共需要三个软件,为了便于找到最新的版本,把官网也放后面:
- Apktool:http://ibotpeaches.github.io/Apktool/install/ 最新版本2.0.3
- dex2jar: https://github.com/pxb1988/dex2jar 最新版本2.0
- JD-GUI: http://jd.benow.ca/ 最新版本1.4.0
这三个软件Apktool的安装稍微麻烦点,dex2jar和JD-GUI 都很容易,下载下来解压了就能用。
1,在官网链接里找到如下所示: 也就是这个链接http://ibotpeaches.github.io/Apktool/install/
基本上按照上面的6个步骤就ok了。第一步是下载一个shell脚本,保存的名字就是”apktool”,不要带.sh后缀,任何后缀都不要带。可以复制到sublimetext,然后保存下。
2,下载最新的apktool-2,目前的最新版本是 apktoll_2.0.3.jar
3,将所下载的jar文件改名为”apktool.jar” , 也就是将 文件名后面的版本号删掉
4,将shell脚本”apktool”和”apktool.jar”, 也就是刚才下载的两个文件,放到 “/usr/local/bin”目录下 , 注意是 usr文件夹, 不是usrs, 相差一个字母,这个usr文件在系统里是隐藏的,要先显示隐藏文件,才能看到
5,增加这两个文件可执行权限,具体步骤是在 usr/local/bin 里打开终端,或者先打开终端再cd到usr/local/bin里,然后在终端里通过 chmod a+x file 这个命令来增加执行权限,注意file是我们刚才放进来的两个文件
也就是分别输入 chmod a+x apktool ,再回车 ,然后再输入 chmod a+x apktool.jar
6、打开终端输入 apktool -v 就可以查看 apktool的版本了
====至此 apktool 的安装 就已经完成
这两个直接下载,然后解压缩就ok:
软件的安装就说到这,下面就是破解的过程了。为了检测下是否能破解,我们先用Apktool反编译,免得我们最后一场空。(只有Apktool能反编译/回编译,我们的破解才有意义)。
1,新建个apk文件夹,将待破译的apk放进去,之后进到这个目录运行命令: apktool d hongbao.apk
<code class="hljs mathematica has-numbering" style="display: block; padding: 0px; background-color: transparent; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-top-left-radius: 0px; border-top-right-radius: 0px; border-bottom-right-radius: 0px; border-bottom-left-radius: 0px; word-wrap: normal; background-position: initial initial; background-repeat: initial initial;">yanzideMacBook-Pro:apk yanzi$ apktool d hongbao.apk
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">Using</span> Apktool <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">2.0</span><span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">.1</span> on hongbao.apk
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Loading resource table...
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Decoding AndroidManifest.xml with resources...
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Loading resource table from file: /Users/yanzi/Library/apktool/framework/<span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">1.</span>apk
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Regular manifest package...
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Decoding file-resources...
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Decoding values */* XMLs...
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Baksmaling classes.dex...
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Copying assets and libs...
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Copying unknown files...
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Copying original files...</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; background-color: rgb(238, 238, 238); top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right;"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li><li style="box-sizing: border-box; padding: 0px 5px;">10</li><li style="box-sizing: border-box; padding: 0px 5px;">11</li><li style="box-sizing: border-box; padding: 0px 5px;">12</li></ul>
目录如下:
之后再运行命令回编译apk:
apktool b hongbao (hongbao 就是反编译出来的文件夹)
<code class="hljs mathematica has-numbering" style="display: block; padding: 0px; background-color: transparent; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-top-left-radius: 0px; border-top-right-radius: 0px; border-bottom-right-radius: 0px; border-bottom-left-radius: 0px; word-wrap: normal; background-position: initial initial; background-repeat: initial initial;">yanzideMacBook-Pro:apk yanzi$ apktool b hongbao
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">Using</span> Apktool <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">2.0</span><span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">.1</span>
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Checking whether sources has changed...
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Smaling smali folder into classes.dex...
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Checking whether resources has changed...
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Building resources...
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">I</span>: Building apk file...</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; background-color: rgb(238, 238, 238); top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right;"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li></ul>
上面的build和dist就是回编译apk过程中生成的东西,编译出来的apk在dist目录下,打开build/apk文件夹会发现少了original文件夹下的META-INF文件夹:
也就意味着dist里的apk文件是没有签名的,这个稍后再谈。
2、要使用dex2jar,
注意修改以下两个文件属性为可执行文件: 记住有两个 文件 都需要 修改为 可执行
chmod +x /home/.../d2j-dex2jar.sh /home/.../d2j_invoke.sh
3、输入以下命令,可以 直接 输入 apk文件 ,也可以 输入 dex文件
3,打开JD-GUI,将生成的 jar拖进去就看到源码了。
通过看java源码对比smali文件,修改后回编译就ok了!
如何手动给apk增加签名?
回编译后的apk是安装不成功的,总是提示
Failure [INSTALL_PARSE_FAILED_UNEXPECTED_EXCEPTION]
实质是没签名。
1,生成签名:
<code class="hljs lasso has-numbering" style="display: block; padding: 0px; background-color: transparent; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-top-left-radius: 0px; border-top-right-radius: 0px; border-bottom-right-radius: 0px; border-bottom-left-radius: 0px; word-wrap: normal; background-position: initial initial; background-repeat: initial initial;">keytool <span class="hljs-attribute" style="box-sizing: border-box;">-genkey</span> <span class="hljs-attribute" style="box-sizing: border-box;">-keystore</span> hongbao<span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">.</span>keystore <span class="hljs-attribute" style="box-sizing: border-box;">-keyalg</span> RSA <span class="hljs-attribute" style="box-sizing: border-box;">-validity</span> <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">10000</span> <span class="hljs-attribute" style="box-sizing: border-box;">-alias</span> hongbao</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; background-color: rgb(238, 238, 238); top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right;"><li style="box-sizing: border-box; padding: 0px 5px;">1</li></ul>
注意:上面-keystore后面跟的是签名文件的名字,而-alias是别名,一般情况下-keystore后面跟-alias是一样的,但其实两者没有关系,这也是我故意搞成不一样的原因。
2,为apk增加签名:
<code class="hljs lasso has-numbering" style="display: block; padding: 0px; background-color: transparent; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-top-left-radius: 0px; border-top-right-radius: 0px; border-bottom-right-radius: 0px; border-bottom-left-radius: 0px; word-wrap: normal; background-position: initial initial; background-repeat: initial initial;">jarsigner <span class="hljs-attribute" style="box-sizing: border-box;">-digestalg</span> SHA1 <span class="hljs-attribute" style="box-sizing: border-box;">-sigalg</span> MD5withRSA <span class="hljs-attribute" style="box-sizing: border-box;">-tsa</span> <span class="hljs-attribute" style="box-sizing: border-box;">-verbose</span> <span class="hljs-attribute" style="box-sizing: border-box;">-keystore</span> hongbao<span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">.</span>keystore <span class="hljs-attribute" style="box-sizing: border-box;">-signedjar</span> hongbao<span class="hljs-attribute" style="box-sizing: border-box;">-signed</span><span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">.</span>apk hongbao<span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">.</span>apk hongbao</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; background-color: rgb(238, 238, 238); top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right;"><li style="box-sizing: border-box; padding: 0px 5px;">1</li></ul>
注意:
1,最后的”hongbao”就是-alias后面带的,必须保持一致。
2,如果不带-digestalg SHA1 -sigalg MD5withRSA签名后的apk安装也是不成功的,说INSTALL_PARSE_FAILED_NO_CERTIFICATES的错误,如果不带-tsa会报一个时间方面的警告。
文中所提到的附件下载:
- Apktool
- dex2jar
- JD-GUI