<安全攻防之反調(diào)試Ptrace>

一. Ptrace (process trace 進程跟蹤)

  • 此函數(shù)提供了一個進程監(jiān)聽控制另外一個進程,并且可以檢測被控制進程的內(nèi)存和寄存器里面的數(shù)據(jù).它可以用來實現(xiàn)斷點調(diào)試和系統(tǒng)調(diào)用跟蹤.debugserver就是用的它.可參考書籍<程序員的自我修養(yǎng)>,在iOS中沒有提供相應的頭文件.

二. 防止應用被附加

在MacOS中,蘋果公司提供了Ptrace函數(shù)的代碼,復制代碼到項目中

/*
  arg1:ptrace 要做的事情
  arg2:要操作的進程ID
  arg3(地址):arg4(數(shù)據(jù)):取決于arg1
*/
ptrace(PT_DENY_ATTACH, 0, 0, 0);
/*
 * Copyright (c) 2000-2005 Apple Computer, Inc. All rights reserved.
 *
 * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
 *
 * This file contains Original Code and/or Modifications of Original Code
 * as defined in and that are subject to the Apple Public Source License
 * Version 2.0 (the 'License'). You may not use this file except in
 * compliance with the License. The rights granted to you under the License
 * may not be used to create, or enable the creation or redistribution of,
 * unlawful or unlicensed copies of an Apple operating system, or to
 * circumvent, violate, or enable the circumvention or violation of, any
 * terms of an Apple operating system software license agreement.
 *
 * Please obtain a copy of the License at
 * http://www.opensource.apple.com/apsl/ and read it before using this file.
 *
 * The Original Code and all software distributed under the License are
 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
 * Please see the License for the specific language governing rights and
 * limitations under the License.
 *
 * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
 */
/* Copyright (c) 1995 NeXT Computer, Inc. All Rights Reserved */
/*-
 * Copyright (c) 1984, 1993
 *    The Regents of the University of California.  All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 * 3. All advertising materials mentioning features or use of this software
 *    must display the following acknowledgement:
 *    This product includes software developed by the University of
 *    California, Berkeley and its contributors.
 * 4. Neither the name of the University nor the names of its contributors
 *    may be used to endorse or promote products derived from this software
 *    without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 * SUCH DAMAGE.
 *
 *    @(#)ptrace.h    8.2 (Berkeley) 1/4/94
 */

#ifndef _SYS_PTRACE_H_
#define _SYS_PTRACE_H_

#include <sys/appleapiopts.h>
#include <sys/cdefs.h>

enum {
    ePtAttachDeprecated __deprecated_enum_msg("PT_ATTACH is deprecated. See PT_ATTACHEXC") = 10
};


#define PT_TRACE_ME     0       /* child declares it's being traced */
#define PT_READ_I       1       /* read word in child's I space */
#define PT_READ_D       2       /* read word in child's D space */
#define PT_READ_U       3       /* read word in child's user structure */
#define PT_WRITE_I      4       /* write word in child's I space */
#define PT_WRITE_D      5       /* write word in child's D space */
#define PT_WRITE_U      6       /* write word in child's user structure */
#define PT_CONTINUE     7       /* continue the child */
#define PT_KILL         8       /* kill the child process */
#define PT_STEP         9       /* single step the child */
#define PT_ATTACH       ePtAttachDeprecated     /* trace some running process */
#define PT_DETACH       11      /* stop tracing a process */
#define PT_SIGEXC       12      /* signals as exceptions for current_proc */
#define PT_THUPDATE     13      /* signal for thread# */
#define PT_ATTACHEXC    14      /* attach to running process with signal exception */

#define PT_FORCEQUOTA   30      /* Enforce quota for root */
#define PT_DENY_ATTACH  31

#define PT_FIRSTMACH    32      /* for machine-specific requests */

__BEGIN_DECLS


int     ptrace(int _request, pid_t _pid, caddr_t _addr, int _data);


__END_DECLS

#endif  /* !_SYS_PTRACE_H_ */


三. 反Ptrace

  • 注入動態(tài)庫
  • 利用fishhook改變函數(shù)的執(zhí)行
int (*ptrace_p)(int _request, pid_t _pid, caddr_t _addr, int _data);

int myPtrace(int _request, pid_t _pid, caddr_t _addr, int _data) {
    if (_request != PT_DENY_ATTACH) {
        return ptrace_p(_request, _pid, _addr, _data);
    }
    return 0;
}

+ (void)load {
    struct rebinding ptraceRebinding;
    ptraceRebinding.name = "ptrace";
    ptraceRebinding.replacement = myPtrace;
    ptraceRebinding.replaced = (void *)&ptrace_p;
    struct rebinding rebinds[] = {ptraceRebinding};
    rebind_symbols(rebinds, 1);
}

四.利用framework防護調(diào)試

應用在加載的時候首先會先加在我們的靜態(tài)/動態(tài)庫文件,然后才會加在我們的代碼文件.所以我們可以利用下邊方法做到反反ptrace調(diào)試.

  • 在項目中添加動態(tài)庫
  • 把防護的代碼寫在動態(tài)庫中.
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市订框,隨后出現(xiàn)的幾起案子喂链,更是在濱河造成了極大的恐慌蛤奢,老刑警劉巖扫茅,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件哥牍,死亡現(xiàn)場離奇詭異卒暂,居然都是意外死亡饶号,警方通過查閱死者的電腦和手機激率,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進店門咳燕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人乒躺,你說我怎么就攤上這事招盲。” “怎么了嘉冒?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵曹货,是天一觀的道長。 經(jīng)常有香客問我讳推,道長顶籽,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任银觅,我火速辦了婚禮礼饱,結果婚禮上,老公的妹妹穿的比我還像新娘究驴。我一直安慰自己慨仿,他們只是感情好,可當我...
    茶點故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布纳胧。 她就那樣靜靜地躺著镰吆,像睡著了一般。 火紅的嫁衣襯著肌膚如雪跑慕。 梳的紋絲不亂的頭發(fā)上万皿,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天,我揣著相機與錄音核行,去河邊找鬼牢硅。 笑死,一個胖子當著我的面吹牛芝雪,可吹牛的內(nèi)容都是我干的减余。 我是一名探鬼主播,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼惩系,長吁一口氣:“原來是場噩夢啊……” “哼位岔!你這毒婦竟也來了如筛?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤抒抬,失蹤者是張志新(化名)和其女友劉穎杨刨,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體擦剑,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡妖胀,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了惠勒。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赚抡。...
    茶點故事閱讀 38,100評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖纠屋,靈堂內(nèi)的尸體忽然破棺而出怕品,到底是詐尸還是另有隱情,我是刑警寧澤巾遭,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布肉康,位于F島的核電站,受9級特大地震影響灼舍,放射性物質(zhì)發(fā)生泄漏吼和。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一骑素、第九天 我趴在偏房一處隱蔽的房頂上張望炫乓。 院中可真熱鬧,春花似錦献丑、人聲如沸末捣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽箩做。三九已至,卻和暖如春妥畏,著一層夾襖步出監(jiān)牢的瞬間邦邦,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工醉蚁, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留燃辖,地道東北人。 一個月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓网棍,卻偏偏與公主長得像黔龟,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,834評論 2 345

推薦閱讀更多精彩內(nèi)容