首页
社区
课程
招聘
[原创]android一个crackme分析和破解
2012-3-4 15:01 28394

[原创]android一个crackme分析和破解

2012-3-4 15:01
28394
android一个crackme分析和破解
这个crackme比较简单,适合新手练手用。主要学习一下工具的使用和基本思路与流程,算是一篇破解入门的教程吧。下面开始。
1.        程序源码如下:
public void onCreate(Bundle savedInstanceState)
  {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    mTextView01 = (TextView)findViewById(R.id.myTextView1);
    mEditText01 = (EditText)findViewById(R.id.myEditText1);
    mEditText01.setOnKeyListener(new EditText.OnKeyListener()
    {
      @Override
      public boolean onKey(View arg0, int arg1, KeyEvent arg2)
      {
        // TODO Auto-generated method stub
        String str="gogo";
        
        if(str.equals("11")){
          mTextView01.setText(str);
          Toast.makeText(EX05_01.this, "right++", Toast.LENGTH_LONG).show();
        }
        else{
          mTextView01.setText(str);
          Toast.makeText(EX05_01.this, "error--", Toast.LENGTH_LONG).show();
        }
        
        /*判断输入的类型是何种,并与系统链接*/
        Linkify.addLinks(mTextView01,Linkify.WEB_URLS|Linkify. EMAIL_ADDRESSES|Linkify.PHONE_NUMBERS);
        return false;
        }
      });
}
字串比较,相同则用Toast显示right++,若不相等则用Toast显示error--.我们若想让它一直显示正确,分析思路如下:a.改str.equals("11")为str.equals("gogo ");b.改if语句。下面看具体实现,我们先用第一种方法。
2.        改字串:
所需工具:ApkTool_GUI_1.3.5内测.exe(论坛有下,找下,好找的), EX05_01.apk(我们一会要破解的程序)
先用ApkTool反编译,生成EX05_01目录

图1:
进入EX05_01\smali\irdc\ex05_01 下,用记事本等你觉得好用的文本编辑工具修改EX05_01$1.smali文件。

图2:
找到如下位置:

图3:
改成一样的。然后用apktool工具重建。用Eclipse运行签名后的apk文件,可以看到已经修改成功。下面介绍第二种方法。
3.        改if语句,改流程:
还是EX05_01$1.smali文件,找到如下位置:

图4:
改两个字串不一样v0 and v1,改if-eqz 为 if-nez。改后保存,重建,运行:

图5:
图6:
图7:
图8:
成功提示,哈哈。

4.        如有写的不对的地方,欢迎指正。最近心情不太好,好多事,写文以记之...hope ......

原apk文件: EX05_01_.apk
破解后的文件: EX05_01.apk

[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课

上传的附件:
收藏
点赞5
打赏
分享
最新回复 (19)
雪    币: 299
活跃值: (300)
能力值: ( LV9,RANK:290 )
在线值:
发帖
回帖
粉丝
clide2000 7 2012-3-20 16:49
2
0
辛苦,学习了。
刚接解这方面,收藏一下。
雪    币: 238
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
周克雷 2012-9-22 20:39
3
0
看了一下,这个CM无论你输入什么,都是拿"gogo"和"11"比较,真是坑爹啊
雪    币: 19
活跃值: (25)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
zhouxixixi 2012-10-23 18:30
4
0
学习了~~~!
雪    币: 485
活跃值: (78)
能力值: ( LV4,RANK:40 )
在线值:
发帖
回帖
粉丝
goddkiller 2012-10-24 08:29
5
0
这个CrackeMe比较简单可以说会点语言的人都看得懂!不过还是要感谢LZ分享经验
雪    币: 139
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
seuer 2012-10-31 10:18
6
0
改两个字串不一样v0 and v1,改if-eqz 为 if-nez。改后保存,重建,运行:
请问一下这个“if-nez ”表示什么含义啊。
雪    币: 247
活跃值: (42)
能力值: ( LV3,RANK:30 )
在线值:
发帖
回帖
粉丝
arsusanh 2012-11-1 20:12
7
0
if eqz 相等
if nez 不相等

不知道那几句删除了会咋样,木有试过。
雪    币: 1
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
ascian 2013-10-13 19:17
8
0
我也很想学习,支持一下
雪    币: 270
活跃值: (234)
能力值: ( LV7,RANK:100 )
在线值:
发帖
回帖
粉丝
wule 2 2014-4-14 20:58
9
0
菜鸟已跟,建立自信。。。。
雪    币: 1
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
Jessecoder 2014-11-24 11:16
10
0
新人 那个smali代码需要去系统的学一下,或者这个怎么去学习?
雪    币: 232
活跃值: (30)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
Riverhac 2014-12-2 09:19
11
0
好文,初学者可以看看
雪    币: 161
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
水灵儿 2017-1-12 14:12
12
0
菜鸟已跟,建立自信。。。。
雪    币: 2
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
passioncsu 2017-2-7 16:31
13
0
这么记,一般if eqz v1,v2 意思就是v1-v2是不是等于0  ,等于0了那肯定就相等了,不等于那就不相等
eqz==  equal zero
nez==  not equal zero

这两天要开始学习android逆向,所以从第一个帖子开始看。哈哈
雪    币: 6818
活跃值: (153)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
聖blue 2017-2-13 02:06
14
0
支持下!!!!!!
雪    币: 40
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
shylqy 2017-2-15 15:55
15
0
只是菜鸟。。。。
雪    币: 2
活跃值: (86)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
睡了全世界 2017-2-15 17:04
16
0
实践了一遍,对于入门的来说确实还是不错的,谢谢楼主分享
雪    币: 36
活跃值: (14)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
a晴天安好 2017-7-13 15:40
17
0
刚开始学习,一步步前进!
雪    币: 1110
活跃值: (544)
能力值: ( LV3,RANK:35 )
在线值:
发帖
回帖
粉丝
王嘟嘟 2017-12-21 17:31
18
0
重新学习,现在是已经走了第一步了吗
雪    币: 159
活跃值: (695)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
xiaozhu头 2019-10-28 19:53
19
0
学习啦。
雪    币: 35
活跃值: (88)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
winkar 2019-10-29 10:53
20
0
Jessecoder 新人 那个smali代码需要去系统的学一下,或者这个怎么去学习?
smali的函数调用、赋值、运算基本跟java是一一对应的,控制流语句则更接近汇编。对照着Java多看看就好了。
游客
登录 | 注册 方可回帖
返回