zoukankan      html  css  js  c++  java
  • 防止tweak依附,App有高招;破解App保护,tweak留一手

    相信大多数AppStore开发者在阅读完《iOS应用逆向工程9》之后,对iOS开发的理解会深入不少。一入侯门深似海,tweak的出现让各种裸奔App的作者瞬间跪了,自己的App被玩弄于股掌之间,内牛满面:cry:
    但是,一些防护性优秀App的出现,给安全性堪忧的AppStore注入了一针强心剂。他们用到的防护方式处于业界领先地位,值得我们学习:handshake:。如北京时间9月30日更新的美团iOS客户端4.8.1版3,就能够强力阻止各种dylib的注入,使得一切tweak均为狗比。下面,小弟就带大家看看美团是怎么做到的,而我们又可以通过什么方式,破解这种防护。
    一、下载美团,把玩把玩
    下载完成,启动App之后,ssh到iOS,运行

    ps -e

    得到输出

     1374 ??         0:03.53 /var/mobile/Applications/DCDC3F9D-227A-414F-B796-54AA9DB0F39A/imeituan.app/imeituan

    好的,拿到了美团的目录路径和进程名。下面我们分别尝试用Cycript注入dylib,和用debugserver来动态调试:

    此处应有图,挂掉了,也找不回来了 sweat_smile

    嗯……事情变得棘手了:注入dylib和动态调试都失败了。动态调试失败,很大的概率是采用了ptrace方法,这里就不赘述了,网上随便搜一搜就有很多例子;而dylib注入失败是大家比较少碰到的情况,我们就从它下手,看看到底发生了什么。

    二、anti-DYLD_INSERT_LIBRARIES
    dylib的注入一般是通过DYLD_INSERT_LIBRARIES这个环境变量来实现的,现在dylib连注入都失败,即其constructor根本未得到执行,说明此行为不是由美团的代码完成的,而应该发生在代码执行前。既然这样的话,此行为多半是因MachO头部的某个标注,导致dyld3有意为之的。那么……
    我们直接去看看dyld的源代码5好了啊!源代码总共也没几行,我们着重看看pruneEnvironmentVariables这个函数,它的注释写道:
    同时注意到这个switch case:

    switch (sRestrictedReason) {
                            case restrictedNot:
                                    break;
                            case restrictedBySetGUid:
                                    dyld::log("main executable (%s) is setuid or setgid
    ", sExecPath);
                                    break;
                            case restrictedBySegment:
                                    dyld::log("main executable (%s) has __RESTRICT/__restrict section
    ", sExecPath);
                                    break;
                            case restrictedByEntitlements:
                                    dyld::log("main executable (%s) is code signed with entitlements
    ", sExecPath);
                                    break;
                    }

    三种情况下,DYLD_环境变量会被dyld无视,分别是:
    1. 可执行文件被setuid或setgid了;
    2. 可执行文件含有__RESTRICT/__restrict这个section;
    3. 可执行文件被签了某个entitlements。
    其中,因为Apple的审核机制,1和3不能由用户指定,因此不大可能出现在AppStore App中。为了确保万无一失,我们简单验证一下就好了:

    FunMaker-5s:~ root# ls -l /var/mobile/Applications/DCDC3F9D-227A-414F-B796-54AA9DB0F39A/imeituan.app/imeituan
    -rwxr-xr-x 1 mobile mobile 25340624 Sep 30 10:23 /var/mobile/Applications/DCDC3F9D-227A-414F-B796-54AA9DB0F39A/imeituan.app/imeituan*
    FunMaker-5s:~ root# ldid -e /var/mobile/Applications/DCDC3F9D-227A-414F-B796-54AA9DB0F39A/imeituan.app/imeituan
    <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
    <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
    <plist version="1.0">
            <dict>
                    <key>keychain-access-groups</key>
                    <array>
                            <string>FSS9ANCQ68.com.meituan.access</string>
                            <string>FSS9ANCQ68.com.meituan.imeituan</string>
                    </array>
    
                    <key>com.apple.developer.pass-type-identifiers</key>
                    <array>
                            <string>T3ZLXP4K5B.*</string>
                    </array>
    
                    <key>application-identifier</key>
                    <string>FSS9ANCQ68.com.meituan.imeituan</string>
    
                    <key>aps-environment</key>
                    <string>production</string>
    
            </dict>
    </plist><?xml version="1.0" encoding="UTF-8" standalone="yes"?>
    <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
    <plist version="1.0">
            <dict>
                    <key>keychain-access-groups</key>
                    <array>
                            <string>FSS9ANCQ68.com.meituan.access</string>
                            <string>FSS9ANCQ68.com.meituan.imeituan</string>
                    </array>
    
                    <key>com.apple.developer.pass-type-identifiers</key>
                    <array>
                            <string>T3ZLXP4K5B.*</string>
                    </array>
    
                    <key>application-identifier</key>
                    <string>FSS9ANCQ68.com.meituan.imeituan</string>
    
                    <key>aps-environment</key>
                    <string>production</string>
    
            </dict>
    </plist>

    可以看到,imeituan这个可执行文件既没有setuid/setgid位,也没有特殊的entitlements,那么它含有__RESTRICT/__restrict这个section的可能性激增。至于如何验证我们的想法,用OSX逆向顶级大牛fG!3的改造版MachOView7看看就好了嘛~


    好了,这应该就是美团4.8.1所采用的大杀器了,这种anti-DYLD_INSERT_LIBRARIES的方法,其实早在iOS 7完美越狱时,已经由GeoHot提到过了5:shocked:膜拜!!!

    三、anti-anti-DYLD_INSERT_LIBRARIES
    既然anti-DYLD_INSERT_LIBRARIES是由__RESTRICT/__restrict实现的,那么anti-anti-DYLD_INSERT_LIBRARIES自然就等同于anti-RESTRICT/restrict咯!而要anti-RESTRICT/restrict也很简单,把imeituan这个可执行文件用macvim等二进制编辑器打开,把所有的__RESTRICT/__restrict字符串给重命名一下就好了,比如:


    这样dyld就找不到__RESTRICT/__restrict,也就不会忽略DYLD_INSERT_LIBRARIES了嘛!
    把改过以后的imeituan拷贝回iOS,

    snakeninnys-MacBook:~ snakeninny$ scp /Users/snakeninny/imeituan root@192.168.3.3:/var/mobile/Applications/DCDC3F9D-227A-414F-B796-54AA9DB0F39A/imeituan.app/imeituan

    因为我们对App的可执行文件进行了静态patch,其md5值已经改变,所以Apple签名失效,正常情况下美团App无法启动。要解决这个问题,很方便,也很惭愧,因为要用到盗版App的利器——AppSync……
    在Cydia中搜索AppSync,安装并respring后即可禁用iOS的签名校验。一切就绪后,打开美团,用Cycript重新测测看:

    FunMaker-5s:~ root# cycript -p imeituan
    cy# [UIApp displayIdentifier]
    @"com.meituan.imeituan"

    打完收工~

    四、总结
    根据我们的分析结果,来一个马后炮,我们可搜到Sam2的一篇新博文23(关键词“DYLD_INSERT_LIBRARIES __RESTRICT”),讲到的正是这个帖子所提到的内容。除了更专业更详细外,他还给出了怎么用这种机制给自己的App加上防护的方法,完爆我们这种只破坏不保护的猥琐行径:huffy:,值得崇拜~!

    参考:
    1. http://www.samdmarshall.com/blog/blocking_code_injection_on_ios_and_os_x.html23
    2. http://geohot.com/e7writeup.html5
    3. http://www.opensource.apple.com/source/dyld/dyld-210.2.3/src/dyld.cpp5
    4. https://theiphonewiki.com/wiki/Launchd.conf_untether1

  • 相关阅读:
    使 div 元素看上去像一个按钮
    ORM框架学习(二)
    ORM框架学习(一)
    创建我的第一个MVC4-基于ASPX
    js实现简单的验证码
    常见开发语言擅长领域
    解决IE兼容问题,IE6,IE7,IE8,IE9,IE10
    EF框架学习(7)---EF中的查询方法
    EF框架学习(6)---EF中的在线场景保存数据
    EF框架学习(5)---EF中的在线和离线场景
  • 原文地址:https://www.cnblogs.com/sunnyke/p/4514760.html
Copyright © 2011-2022 走看看