Stay in Your Cage! A Sound Sandbox for Third-Party Libraries on Android

背景:

本文于2016年9月发表在期刊Computer Security-ESORICS 2016上,文中主要介绍了一种自主研发的沙箱工具,该工具对app中的第三方库分别建立沙箱,对app的权限使用及文件空间的访问提供保证。

出处:

Computer Security – ESORICS 2016

Volume 9878 of the seriesLecture Notes in Computer Sciencepp 458-476

作者:

Fabo Wang, Yuqing Zhang, Kai Wang, Peng Liu, Wenjie Wang


概述及主要成果:

本文通过对app中的第三方库分别建立沙箱对app的权限使用及文件空间的访问进行保证。开发一款对开发者友好的工具LibCage。该工具禁止权限滥用,保护用户隐私且没有改写Android framework或是库文件(之前的研究对文件进行改写,适用性差)。

实现方法:

LibCage 对app中的LibFinder分别建立沙箱。每个沙箱被分配一个权限集合,该集合由开发者制定。此外,LibCage还关注一些比较危险的权限,对使用这些权限的API进行监控。

在每个app中安置permission checker,当app中的LibFinder尝试进行一些敏感操作时,对其权限进行验证。permission checker 还对文件的访问是否合法进行判断。

设置Controller(monitoring proxy)监测第三方库的行为。通过干预lib对敏感方法的调用,将这些调用重定向到Controller,进而对这些调用进行监控(基于系统调用中断,system call interception),该方法对java lib和native lib都有效。

具体流程:

Controller监控一些有敏感权限的API的lib,并对其函数调用,文件访问进行监控,在函数或方法调用过程中将其截获,之后checker对其进行检查,如果判断该调用合法,则将该调用指向原被调用函数,否则该调用被阻断。Figure 4和Figure 5分别表示了LibCage对java lib及对native lib的处理:


checker对权限的检查依据用户指定的权限策略,该策略规则存在Policy.xml文件中,在LibCage初始化时由用户定义。该文件定义了一些方法和函数与权限的映射,并决定对内部文件的访问是否合法。下图展示了Policy.xml的部分设置:


如上图所示,文件定义了java lib lib.package.name和native lib nativelib.so的权限。


总结

优点:

通过对每一个lib分别建立沙箱来防止越权问题和文件非法访问,对函数和方法的调用进行拦截并检测其安全性。在文章的evaluation部分提到这种拦截行为对用户是透明的,在实际应用中不会对程序运行有影响(合法的程序)。

缺点:

对每一个沙箱所具有的权限进行人工定义,适用性较差。对函数的拦截等可能是用hook技术实现的,想要实现这一步可能需要对用户机进行root。


由于该文章的查阅是付费的,所以只能看到文章的一部分章节,关于Controller和checker具体的工作过程并没有看到。

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

推荐阅读更多精彩内容