美文网首页
iOS 应用安全性

iOS 应用安全性

作者: bigCatloveFish | 来源:发表于2018-06-09 16:48 被阅读23次

1,通过对CodeResources读取资源文件原始hash,和当前hash进行对比,判断是否经过篡改,被篡改过的文件应从服务器重新请求资源文件进行替换,或者引导用户从正规渠道重新下载app。CodeResources文件是一个属性列表,包含bundle中所有其他文件的列表。这个属性列表可能有多个files,这是一个字典,其中键是文件名,值通常是Base64格式的散列值。如果键表示的文件是可选的,那么值本身也是一个字典,这个字典有一个hash键和一个optional键,如果文件被修改,其对应的hash也会改变。所以CodeResources文件内的hash可以用于判断一个应用程序是否完好无损。
2,可以通过检测cryptid的值来检测是否被篡改,篡改过cryptid的值为0。
3,
如果以上都满足不了的话,可以自己对需要保护的重要文件做MD5hash校验。使用这个框架FileMD5Hash生成hash。通过对比原始文件的hash和当前的hash来做判断。只要文件的内容有被改变,hash的值一定会变,目前的破解技术都会修改到系统文件、比如CodeResources、Info.plist。

举个例子,给bundle里面所有的文件生成hash。
1.读取bundle所有文件名

//获得所有资源文件名
-(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];
//                NSLog(@"%@",fileName);
            }
        }
    }
    return arr;
}

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

相关文章

  • iOS OC代码混淆

    由于iOS系统下,应用沙盒是封闭的,所以iOS应用相对于安卓应用来说,安全性稍微高一些,但是这并不能代表iOS应用...

  • iOS 应用安全性

    1,通过对CodeResources读取资源文件原始hash,和当前hash进行对比,判断是否经过篡改,被篡改过的...

  • ios 的Today插件

    iOS8新特性扩展(Extension)应用之一——Today扩展 一、理解扩展 1、简介 基于iOS系统的安全性...

  • iOS8新特性扩展(Extension)应用之一Today扩展无

    iOS8新特性扩展(Extension)应用之一——Today扩展 一、理解扩展 1、简介 基于iOS系统的安全性...

  • 如何确保APP的安全性

    iOS应用的安全性 常常被大家忽视。iOS 如何做才安全:1、首先,我们可以通过软件 下载 AppStore的ip...

  • iOS安全攻防(一) 如何确保APP的安全性

    iOS应用的安全性 常常被大家忽视。iOS 如何做才安全:1、首先,我们可以通过软件 下载 AppStore的ip...

  • App Extension

    Extension概述 众所周知,基于iOS系统的安全性考虑,其应用的数据存储是通过沙盒模式进行的,要实现应用之间...

  • iOS Schemes的使用

    我们都知道,iOS系统为了数据的安全性,对每个应用存储的数据进行安全处理,即沙盒存储机制。使得应用的存储空间是彼此...

  • iOS App的加固保护原理 来源:Freebuf.com

    苹果系统的封闭性导致iOS APP安全性比较高,但是实际上iOS应用本身被破解的难度并不高,一旦在越狱设备上,ip...

  • 通俗易懂的讲解iOS中的证书知识

    前言: iOS应用以流畅和安全著称,其中的安全性主要依靠的就是苹果开发中使用的一套证书流程。证书是用来给应用程序签...

网友评论

      本文标题:iOS 应用安全性

      本文链接:https://www.haomeiwen.com/subject/tbnteftx.html