Android静态安全检测 -> Zip文件目录遍历漏洞

Zip文件目录遍历漏洞 - ZipEntry.getName方法


一、API


1. 继承关系


【1】java.lang.Object

【2】java.util.zip.ZipEntry


2. 主要方法


【1】getName()   返回String(entry的名字)


【2】isDirectory()  返回Boolean(是否为directory entry)


【3】参考链接(Android developers)


https://developer.android.com/reference/java/util/zip/ZipEntry.html


3. 使用ZipEntry类解压zip文件


【1】代码示例




【2】参考链接


http://blog.csdn.net/jiangwei0910410003/article/details/52118575


二、触发条件


1. 定位getName方法


【1】对应到smali语句中的特征

Ljava/util/zip/ZipEntry;->getName()Ljava/lang/String;


2. 方法内查询getNextEntry()

Ljava/util/zip/ZipInputStream;->getNextEntry()Ljava/util/zip/ZipEntry;

参考链接:https://developer.android.com/reference/java/util/zip/ZipInputStream.html#getNextEntry()


3. 判断是否过滤特殊字符  "../"


4. 漏洞代码示例




三、漏洞原理


【1】使用ZipEntry.getName()解压zip文件,没有对上级目录字符串(../)进行过滤校验,可能会导致被解压的文件发生目录跳转,解压到其他目录,并且覆盖相应的文件,最终导致任意代码执行


【2】更多内容


https://jaq.alibaba.com/community/art/show?articleid=383


http://www.droidsec.cn/android安全开发之zip文件目录遍历/


http://wolfeye.baidu.com/blog/traversal-zip-file/


四、修复建议


【1】解压zip文件时,判断文件名是否有../特殊字符




【2】对重要的Zip压缩包文件进行数字签名校验,校验通过才进行解压


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值