ios敏感邏輯的保護(hù)方案

本文轉(zhuǎn)載自(https://blog.csdn.net/yiyaaixuexi/article/details/29210413)
Objective-C代碼容易被hook饭入,暴露信息太赤裸裸摧找,為了安全,改用C來寫吧骗随!

image

當(dāng)然不是全部代碼都要C來寫颜价,我指的是敏感業(yè)務(wù)邏輯代碼。

本文就介紹一種低學(xué)習(xí)成本的洪规,簡易的敷搪,Objective-C邏輯代碼重寫為C代碼的辦法。

也許留量,程序中存在一個類似這樣的類:

@interface XXUtil : NSObject + (BOOL)isVerified;+ (BOOL)isNeedSomething;+ (void)resetPassword:(NSString *)password; @end

被class-dump出來后窄赋,利用Cycript很容易實現(xiàn)攻擊,容易被hook楼熄,存在很大的安全隱患忆绰。

image

想改,但是不想大改程序結(jié)構(gòu)可岂,腫么辦呢错敢?

把函數(shù)名隱藏在結(jié)構(gòu)體里,以函數(shù)指針成員的形式存儲缕粹。

這樣做的好處是稚茅,編譯后,只留了下地址平斩,去掉了名字和參數(shù)表亚享,提高了逆向成本和攻擊門檻。

改寫的程序如下:

//XXUtil.h#import <Foundation/Foundation.h> typedef struct _util {    BOOL (*isVerified)(void);    BOOL (*isNeedSomething)(void);    void (*resetPassword)(NSString *password);}XXUtil_t ; #define XXUtil ([_XXUtil sharedUtil]) @interface _XXUtil : NSObject + (XXUtil_t *)sharedUtil;@end
//XXUtil.m#import "XXUtil.h" static BOOL _isVerified(void){    //bala bala ...    return YES;} static BOOL _isNeedSomething(void){    //bala bala ...    return YES;} static void _resetPassword(NSString *password){    //bala bala ...} static XXUtil_t * util = NULL;@implementation _XXUtil +(XXUtil_t *)sharedUtil{    static dispatch_once_t onceToken;    dispatch_once(&onceToken, ^{        util = malloc(sizeof(XXUtil_t));        util->isVerified = _isVerified;        util->isNeedSomething = _isNeedSomething;        util->resetPassword = _resetPassword;    });    return util;} + (void)destroy{    util ? free(util): 0;    util = NULL;}@end
image

最后绘面,根據(jù)Xcode的報錯指引欺税,把以前這樣的調(diào)用

[XXUtil isVerified];

對應(yīng)改成:

XXUtil->isVerified();

就可以了。

是的揭璃,絕不費(fèi)一點(diǎn)腦子晚凿。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市瘦馍,隨后出現(xiàn)的幾起案子歼秽,更是在濱河造成了極大的恐慌,老刑警劉巖情组,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件哲银,死亡現(xiàn)場離奇詭異扛吞,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)荆责,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來亚脆,“玉大人做院,你說我怎么就攤上這事”舫郑” “怎么了键耕?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長柑营。 經(jīng)常有香客問我屈雄,道長,這世上最難降的妖魔是什么官套? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任酒奶,我火速辦了婚禮,結(jié)果婚禮上奶赔,老公的妹妹穿的比我還像新娘惋嚎。我一直安慰自己,他們只是感情好站刑,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布另伍。 她就那樣靜靜地躺著,像睡著了一般绞旅。 火紅的嫁衣襯著肌膚如雪摆尝。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天因悲,我揣著相機(jī)與錄音堕汞,去河邊找鬼。 笑死囤捻,一個胖子當(dāng)著我的面吹牛臼朗,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蝎土,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼视哑,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了誊涯?” 一聲冷哼從身側(cè)響起挡毅,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎暴构,沒想到半個月后跪呈,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體段磨,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年耗绿,在試婚紗的時候發(fā)現(xiàn)自己被綠了苹支。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,018評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡误阻,死狀恐怖债蜜,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情究反,我是刑警寧澤寻定,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站精耐,受9級特大地震影響狼速,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜卦停,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一向胡、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧沫浆,春花似錦捷枯、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至本股,卻和暖如春攀痊,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背拄显。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工苟径, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人躬审。 一個月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓棘街,卻偏偏與公主長得像,于是被迫代替她去往敵國和親承边。 傳聞我的和親對象是個殘疾皇子遭殉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評論 2 345

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