使用baksmali和smali反编译和编译apk

到官网去下 
地址  要下那个1.3.2的

玩了个游戏《GunStrike》,挺好玩的,但是确实难度太高了,玩了半天才解锁一把枪,于是想去修改程序,破解它,但是最好还是没破解成功,它的数据都不在程序里,好像是存在文件里了,我找了半天也没找到,而且程序也进行代码混淆了,基本没法看,但是还是学了下反编译出smali文件,然后修改后可以再编译回dex文件,然后可以塞回包里使用。

为了方便,把baksmali和smali都放到androidsdk安装路径下的tools里面,然后老规矩,把apk文件改成rar文件,解压后取出classes.dex文件,也放入tools里面,然后用cmd,cd  到tools目录下,
j ava-jar baksmali-1.3.2.jar -o classout/ classes.dex  
前提是你的path路径中有你的Java安装目录下的bin文件夹路径,这样才可以在任意路径下使用java命令,还有classout/后要加个空格

执行成功后你会发现,tools目录下多了一个classout文件夹,里面就是smali类型的文件,里面是反编译出的代码,但是不是java代码,还是能看出变量和方法的,
我们可以用这个: http://blog.sina.com.cn/s/blog_70677d110100wufa.html
用jd_gui来看反编译出的Java代码,这样便于寻找自己想要改的东西,找到后可以到baksmaliclassout下去修改相应的地方。然后是利用smali编译回去:
用命令:
java -jar smali-1.3.2.jar classout/ -o classes.dex
可以把classout下编译成classes.dex然后就可以把classes.dex放回.apk下覆盖原来的classes.dex文件。

你可能感兴趣的:(Android开发)