防止关键文件被修改的安全问题

修改 Info.plist 文件中文件名字段
重新安装 ipa 文件后程序能够正常打开
漏洞危害:客户端程序如果没有自校验机制的话,攻击者可能会通过篡改客
户端程序窃取手机用户的隐私信息。
建议:应用在提交给 Apple Store 后其可执行文件会被修改,所以开发
时不能将自身 hash 硬编码进程序中,建议应用通过对关键文件进行服务端 hash
校验的方式判断是否被篡改。

  • 如何防止文件被篡改

方法一

简单测试了下每次重新打包的ipa里面的hash值有些是可变的,这个要自己注意下

通过对CodeResources读取资源文件原始hash,和当前hash进行对比,判断是否经过篡改,被篡改过的文件应从服务器重新请求资源文件进行替换,或者引导用户从正规渠道重新下载app。CodeResources文件是一个属性列表,包含bundle中所有其他文件的列表。这个属性列表可能有多个files,这是一个字典,其中键是文件名,值通常是Base64格式的散列值。如果键表示的文件是可选的,那么值本身也是一个字典,这个字典有一个hash键和一个optional键,如果文件被修改,其对应的hash也会改变。所以CodeResources文件内的hash可以用于判断一个应用程序是否完好无损。
下面打开CodeResources文件,看看里面都有什么

21a89f34c14e4a8bb9575ae9ba95348a.jpg
8b9251c38cb140c5b5b080b724290b5f.jpg
280d668d0ba64daca6a0f911f0702ab8.jpg

上图可以看到文件在CodeResources里面对应的hash。

  • 从CodeResources获取当前文件的hash
280d668d0ba64daca6a0f911f0702ab8-2.jpg
  • 从CodeResources获取原始文件的hash
    思路是,从ipa里拷贝这个文件保存到后台服务器,app里从服务器下载这个文件读取内容进行比较。

方法二

  1. 可以通过检测cryptid的值来检测是否被篡改,篡改过cryptid的值为0。原理看iOS平台游戏安全之IPA破解原理及防御(第三弹)

以上方法转自https://www.it610.com/article/1388824658266116096.htm

方法三---推荐

1.首先导入头文件:

#include <CommonCrypto/CommonDigest.h>

2.获取所有资源文件

//获得所有资源文件名
+ (NSArray *)allFilesAtPath:(NSString *)dir{
    NSMutableArray * arr = [NSMutableArray array];
    NSFileManager * manager = [NSFileManager defaultManager];
    NSArray *temp = [manager contentsOfDirectoryAtPath:dir error:nil];
    
    for (NSString * fileName in temp) {
        BOOL flag = YES;
        NSString * fullpath = [dir stringByAppendingPathComponent:fileName];
        if ([manager fileExistsAtPath:fullpath isDirectory:&flag]) {
            if (!flag ) {
                [arr addObject:fileName];
            }
        }
    }
    return arr;
}

3.生成资源文件名及对应的hash的字典

经发现模拟器的数值和真机的数值是不一样的,所以真正上线的时候需要取真机的数值,生成文件或者数据可以保存在后端,最好根据版本号的不同调用相应的数据

//生成资源文件名及对应的hash的字典, eg:@{@"appicon":@"wegdfser45t643232324234"};
+ (NSDictionary *)getBundleFileHash{
    NSMutableDictionary * dicHash = [NSMutableDictionary dictionary];
    NSArray * fileArr = [self allFilesAtPath:[[NSBundle mainBundle]resourcePath]];
    for (NSString * fileName in fileArr) {
        //对应的文件生成hash
        if (![fileName containsString:@".png"] && ![fileName containsString:@".plist"]) {
            continue;
        }
        NSString * HashString = [self computeHashForFile:[[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:fileName]];
//        NSString * HashString = [FileHash md5HashOfFileAtPath:[[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:fileName]];
        if (HashString != nil) {
            [dicHash setObject:HashString forKey:fileName];
        }
    }
    //所有资源文件的hash就保存在这数组里
//    NSLog(@"-----%@",dicHash);
    return dicHash;
}

+ (NSString *)computeHashForFile:(NSString *)filePath {
    NSString *fileContentsHash;
    if ([[NSFileManager defaultManager] fileExistsAtPath:filePath]) {
        NSData *fileContents = [NSData dataWithContentsOfURL:[NSURL fileURLWithPath:filePath]];
        fileContentsHash = [self computeHashForData:fileContents];
    }
    return fileContentsHash;
}

+ (NSString *)computeHashForData:(NSData *)inputData {
    uint8_t digest[CC_MD5_DIGEST_LENGTH];
    CC_MD5(inputData.bytes, (CC_LONG)inputData.length, digest);
    NSMutableString *inputHash = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH * 2];
    for (int i = 0; i < CC_MD5_DIGEST_LENGTH; i++) {
        [inputHash appendFormat:@"%02x", digest[I]];
    }
    return inputHash;
}

4.比对文件哈希值 校验完整性

其中有些文件如.cer 和 app 文件会随着编译环境和系统导致变化,我们最主要的就是取这些不会变化的文件进行对比
所以我只取了png和info.plist文件进行校验,其中info.plist文件为最主要的

/**
 比对文件哈希值 校验完整性
 @param info 服务器端的文件哈希值
 */

static const inline NSDictionary* fileHashDic(){
    return @{
        @"AppIcon40x40@3x.png" : @"8cab8f895afa54c554dfeb079db9023e",
        @"AppIcon60x60@3x.png" : @"86b94a7b880cfa7f0786a5b777a53288",
        @"launchScreen_bj2.png" : @"44fdc6968a8644ae44d594ebace41ece",
        @"AppIcon29x29@3x.png" : @"96d607adebc5105529aee5ea9d57b7c7",
        @"LaunchImage-800-Portrait-736h@3x.png" : @"04f60196365bb1fccf6c628391fbd283",
        @"Info.plist" : @"06079af00bfa273602ebe8d5dbede664",
        @"AppIcon20x20@3x.png" : @"2561cf41c5302c9465aa709e53000407",
        @"AppIcon60x60@2x.png" : @"8cab8f895afa54c554dfeb079db9023e",
        @"LaunchImage@2x.png" : @"43e5a1d1af8d77fb3301bcaf3e4d4150",
        @"LaunchImage-1200-Portrait-2688h@3x.png" : @"b820aae5eaf683460ffeb9fba9b6ec9c",
    };;
}

+ (void)toGetVersionToCheck {
    
    if (![fileHashDic() isEqualToDictionary:[self getBundleFileHash]]) {
        
        NSLog(@"文件被串改!");
        dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
            exit(0);
        });
    }
}

5.判断Mach-O文件否被篡改,存在SignerIdentity这个key就说明被二次打包

//判断Mach-O文件否被篡改
+ (BOOL)checkMach_O
{
    
    NSBundle *bundle = [NSBundle mainBundle];
    NSDictionary *info = [bundle infoDictionary];
    if ([info objectForKey: @"SignerIdentity"] != nil){
        //存在这个key,则说明被二次打包了
        return YES;
    }
    
    return NO;
}

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

推荐阅读更多精彩内容