热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

解决POC脚本对多种URL的自适应问题

在批量POC的过程中,我们采集到的URL状态往往是不同的.因此我们需要对URL进行统一处理,从而确保POC脚本能够准确的验证每个URL我们以实际漏洞举例说明,并给出我的批量POC

在批量POC的过程中,我们采集到的URL状态往往是不同的.
因此我们需要对URL进行统一处理,从而确保POC脚本能够准确的验证每个URL

我们以实际漏洞举例说明,并给出我的批量POC解决方案.

漏洞示例

Atlassian Confluence 5.8.17 之前版本中存在漏洞,该漏洞源于spaces/viewdefaultdecorator.actionadmin/viewdefaultdecorator.action文件没有充分过滤‘decoratorName‘参数。远程攻击者可利用该漏洞读取配置文件。

详情参考:
http://zone.wooyun.org/content/27104
http://www.cnnvd.org.cn/vulnerability/show/cv_id/2016010311
https://web.nvd.nist.gov/view/vuln/detail?vulnId=CVE-2015-8399

该文件遍历漏洞利用很简单,只要访问这个位置,就可以列出当前目录文件:
/spaces/viewdefaultdecorator.action?decoratorName=.

现在我们在搜索引擎采集到的URL有如下几种状态:

1 wiki.kuali.org
2 http://dev.aixuedai.com:8090/
3 https://wiki.netdef.org/display/osr/Home
4 http://cwiki.apache.org/confluence/display/Hive/HCatalog/?id=2#

现在我们考虑POC如何编写才能适应以上这些不同形式的URL

解决方案

前两种我们统一URL格式,使POC脚本能够正确打开即可.而第三第四种情况,我们采集到的URL有多层目录,甚至有POST参数,我们从哪一层开始添加payload做验证呢?

这里我采用的一种方式是:先整理格式,然后取出URL有用的部分组合成新的URL,再针对多成目录进行组合遍历.

操作过程

  1. 原始URL:
    http://cwiki.apache.org:8090/confluence/display/Hive/HCatalog/?id=2#
  2. 提取后的URL:
    protocol: http
    domain name: cwiki.apache.org
    port: 8090
    path: /confluence/display/Hive/HCatalog/
    params: id=2
    fragments: #
  3. 将path分解
    path_list = [‘confluence’, ‘display’, ‘Hive’, ‘HCatalog’]
  4. 去掉无用部分,枚举path字段,组合成新的URL
    poc_list = [
    ‘http://cwiki.apache.org:8090‘,
    ‘http://cwiki.apache.org:8090/confluence‘,
    ‘http://cwiki.apache.org:8090/confluence/display‘,
    ‘http://cwiki.apache.org:8090/confluence/display/Hive‘,
    ‘http://cwiki.apache.org:8090/confluence/display/Hive/HCatalog’
    ]
  5. 对4中的每个URL字符串结尾加上/spaces/viewdefaultdecorator.action?decoratorName=.做验证

批量实践

使用Python内建模块urlparse来格式化URL,我添加了以下两个函数来满足我们的需求.

def get_domain(url):
    """
    added by cdxy May 8 Sun,2016

    Use:
    get_domain(‘http://cdxy.me:80/cdsa/cda/aaa.jsp?id=2#‘)

    Return:
    ‘http://cdxy.me:80‘
    """
    p = urlparse(url)
    return urlunsplit([p.scheme, p.netloc, ‘‘, ‘‘, ‘‘])


def iterate_path(ori_str):
    """
    added by cdxy May 8 Sun,2016

    Use:
    iterate_path_to_list(‘http://cdxy.me:80/cdsa/cda/aaa.jsp?id=2#‘)

    Return:
    [‘http://cdxy.me:80/path1/path2/index.jsp?id=2#‘,
     ‘http://cdxy.me:80/‘
     ‘http://cdxy.me:80/cdsa‘,
     ‘http://cdxy.me:80/cdsa/cda‘,
     ‘http://cdxy.me:80/cdsa/cda/aaa.jsp‘]

    """
    parser = urlparse(ori_str)
    _ans_list = [ori_str]
    _ans_list.append(get_domain(ori_str))
    _path_list = parser.path.replace(‘//‘, ‘/‘).strip(‘/‘).split(‘/‘)

    s = ‘‘
    for each in _path_list:
        s += ‘/‘ + each
        _ans_list.append(urljoin(ori_str, s))
    return _ans_list

此漏洞的POC脚本现已集成到我的并发框架:

扫描结果326 / 736命中率还是挺高的:

技术分享

  • 并发框架 https://github.com/Xyntax/POC-T
  • 修改后的urlparser.py https://github.com/Xyntax/POC-T/blob/master/lib/utils/urlparser.py
  • 本漏洞验证模块 https://github.com/Xyntax/POC-T/blob/master/module/confluence-file-read.py

解决POC脚本对多种URL的自适应问题


推荐阅读
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 本文讲述了作者通过点火测试男友的性格和承受能力,以考验婚姻问题。作者故意不安慰男友并再次点火,观察他的反应。这个行为是善意的玩人,旨在了解男友的性格和避免婚姻问题。 ... [详细]
author-avatar
lzmhezy198344
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有