Xcode番外__获取到“调用我的地址”和“调用我的那个函数的地址”

一.目标

  • 1.找到内存中调用setupNotification方法的位置
  • 2.找到调用setupNotification的方法funcationA的位置
- (void)viewDidLoad{
    [self funcationA];
}

- (void)funcationA{

     self.name = @"lijiachao";
    [self setupNotification];
    
    //自定的某个类的某个方法
    [LRDocumentPath fetchPath];
}

- (void)setupNotification{
      NSLog(@"woshiXXX");
}

在正向开发中,比较简单,都不用找,或者看代码就好了。但是在逆向开中,没有看到代码,那么如何找到那?方法有两种:

  • 1.通过Xcode逆向开发
  • 2.使用debugserver+lldb组合开发

二.基础概念

众所周知,在逆向开发中.
我们如果想知道我调用了谁,去Hopper或者IDA中看就好了,
但是怎么看到谁调用了我是个难题。但也有方法:

  • 1.如果使用debugserver+lldb组合,可以使用po $lr,打印地址;可以获取到”调用我的位置,然后通过减去偏移量获取基址地址,然后在hopper中找到,然后就可以看到funcationA的位置。两个地址都获得了.
  • 2.使用Xcode调试。看右侧的即可。今天主要讲解Xcode调试方法

先去了解Xcode几个按钮的名称和功能

Jietu20170714-195414.jpg
//
//  LRTest1Controller.m
//  LLDBTest
//
//  Created by 王鑫 on 2017/7/14.
//  Copyright © 2017年 王鑫. All rights reserved.
//

#import "LRTest1Controller.h"

@interface LRTest1Controller ()
/** view */
@property(strong,nonatomic)  UIView *bgView;
/** money */
@property(assign,nonatomic)CGFloat money;
@end

@implementation LRTest1Controller

- (void)viewDidLoad {
    [super viewDidLoad];
    
    [self button:nil];
}
- (IBAction)button:(id)sender {
    if (self.person) {
//        NSLog(@"有人\n name  = %@,age = %ld",self.person.name,self.person.age);
        [self setupName];
        self.money = 100.;
    }else{
        LRPerson *per = [[LRPerson alloc] init];
        per.name = @"王鑫";
        NSLog(@"%@",per.name);
    }
}

- (void)setupName{
    self.person.name = @"bbb";
    [self logSome];
    [self createSubViews];
    [self removeSomeViews];
}


- (void)logSome{
    
    NSLog(@"有人\n name  = %@,age = %ld",self.person.name,self.person.age);
}

- (void)createSubViews{
    self.bgView = [[UIView alloc] init];
    [self.view addSubview:self.bgView];
    self.bgView.frame = CGRectMake(100, 400, 100, 100);
}

- (void)removeSomeViews{
    NSLog(@"-------");
}



@end

简介:

  • 第四个按钮:单步执行
  • 第五个按钮:跟入执行
  • 第六个按钮:返回到调用我的位置

三.实际操作

第四个按钮:单步执行
一步一步执行,如果某一步是个方法,我们不进入方法内部,继续往下执行.

Jietu20170715-101813-HD.gif

第五个按钮:跟入执行,进入到函数的内部.

Jietu20170715-102132-HD.gif

第六个按钮:返回到调用我的位置

Jietu20170715-100725.jpg

左侧就会一直返回到调用我的位置。
如果这个是Xcode正向开发,那么很好,可以看到调用我的那个方法名称,但是如果是逆向开发的时候,那么有些方法看不到,我们使用了Hook勾住,所以切记左侧的都是一些乱东西,我们要将页面拉倒顶部,然后就可以看到调用我的函数,获取到偏移函数的位置

正向开发图可以直接看到”调用我的函数名”

四.查找“调用我的位置”和“谁调用了我那个函数的名称”

查找调用我的位置有三个:

  • 1.点击调用栈,然后就可以看到了
  • 2.1 逆向环境下:一下一下点击第五个按钮,直到跳转到汇编页面
  • 2.2 正向环境下:一下一下点击第五个按钮,就可以跳转到了调用我的地方
  • 3.点击第六个按钮即可

查找调用我的那个函数:

当我们在断点出,一下一下点击第五个按钮,直到跳转到汇编页面为止,然后将页面向上拉到顶部,看到的地址就是实际在内存的地址.

逆向开发中,一下一下点击,直到出现汇编才行(或者是点击第六个按钮,直接返回到调用的地方)
找到了调用他的函数
向上拉到顶,获取到函数调用调用他的地址

获取到“调用我的那个函数”的实际内存地址是0x101208c2c

为什么要一下一下的点击,直到汇编页面

因为我们这个是反汇编,所以看不到他们的源码,所以只能点一下,再点一下,直到获得汇编页面
正向开发中,我们点击第五个按钮的时候,是一句一句看的见的代码在执行,但是没有源码的情况下,我们只能点一下,点一下的尝试,直到汇编页面.

获取偏移地址

既然我们在Xcode中调试应用程序,那么我们就在这里不适用debuge+lldb那个经典的方式去获得应用的偏移量了.
直接在Xcode中打印获得偏移量0x00000000000ac000

(lldb) image list -o -f
[  0] 0x00000000000ac000 /Users/wangxin/Library/Developer/Xcode/DerivedData/IPAPatch-hcpqapxbshyvjsajulgtoonbuagq/Build/Products/Debug-iphoneos/WeChat.app/WeChat
[  1] 0x00000000000dc000 /Users/wangxin/Library/Developer/Xcode/iOS DeviceSupport/9.2 (13C75)/Symbols/usr/lib/dyld
...
[327]                    __lldb_objc_find_implementation_for_selector
[328]                    __lldb_caller_function
[329]                    __lldb_apple_objc_v2_get_dynamic_class_info
[336] 0x0000000003b7c000 /Users/wangxin/Library/Developer/Xcode/iOS DeviceSupport/9.2 (13C75)/Symbols/System/Library/Frameworks/Accelerate.framework/Frameworks/vImage.framework/Libraries/libCGInterfaces.dylib
(lldb) 

遵循公式 Hopper的地址 = 实际内存地址 - 偏移量

hopper地址 = 0x101208c2c - 0x00000000000ac000 = 000000010115cc2c

hopper中找到调用者的地址和名称

hopper的地址找到,然后在Hopper中查找

Jietu20170714-202120@2x.jpg

在这里输入000000010115cc2c地址

可以获取到方法是


[WebViewA8KeyLogicImpl handleOnGetA8KeyOK:reason:req:]:

Jietu20170714-202303.jpg

ps:
1.之前我在断点处,直接打印lr的内存地址,试图找到调用者的内存地址,然后减去了偏移地址但是结果不对,现在看来,是我的位置不对

2.hopperIDA他们的地址是相对于偏移地址 = 0而言的

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,565评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,021评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,003评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,015评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,020评论 5 370
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,856评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,178评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,824评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,264评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,788评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,913评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,535评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,130评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,102评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,334评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,298评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,622评论 2 343

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,488评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,019评论 4 62
  • 面试题:开启浏览器窗口,部分页面会闪烁一下。是因为页面在加载数据和解析是从上向下执行的,所以前面的界面信息先加载,...
    小草莓蹦蹦跳阅读 452评论 0 0
  • 家庭 总有人在那说哈:“互联网让人们互相疏远,因为沉迷在网络的虚拟关系中,耽误了和现实的活人打交道。”可是就在前两...
    朱进伟西农阅读 501评论 0 1
  • 简介 住在一个寝室的小莫,陈晨,安然之间有着不同的关系。小莫打架被开除了,临走的时候,她对安然说:“你知道爱一个人...
    南极的狗阅读 210评论 0 0