Skip to content
On this page

可自定义参数的 PoC

自定义参数示例及使用方法

如果你需要编写一个可以交互参数的 PoC 文件(例如有的 PoC 脚本需要填写登录信息,或者任意命令执行时执行任意命令),那么可以在 PoC 文件中声明一个 _options 方法。一个简单的例子如下:

from pocsuite3.api import Output, POCBase, POC_CATEGORY, register_poc, requests, VUL_TYPE
from pocsuite3.api import OrderedDict, OptString


class DemoPOC(POCBase):
    vulID = '0'
    version = '1.0'
    author = ['seebug']
    vulDate = '2019-2-26'
    createDate = '2019-2-26'
    updateDate = '2019-2-25'
    references = ['']
    name = '自定义命令参数登录例子'
    appPowerLink = 'http://www.knownsec.com/'
    appName = 'test'
    appVersion = 'test'
    vulType = VUL_TYPE.XSS
    desc = '''这个例子说明了你可以使用console模式设置一些参数或者使用命令中的'--'来设置自定义的参数'''
    samples = []
    category = POC_CATEGORY.EXPLOITS.WEBAPP

    def _options(self):
        o = OrderedDict()
        o["username"] = OptString('', description='这个poc需要用户登录,请输入登录账号', require=True)
        o["password"] = OptString('', description='这个poc需要用户密码,请输出用户密码', require=False)
        return o

    def _verify(self):
        result = {}
        payload = "username={0}&password={1}".format(self.get_option("username"), self.get_option("password"))
        r = requests.post(self.url, data=payload)
        if r.status_code == 200:
            result['VerifyInfo'] = {}
            result['VerifyInfo']['URL'] = self.url
            result['VerifyInfo']['Postdata'] = payload

        return self.parse_output(result)

    def _attack(self):
        return self._verify()


register_poc(DemoPOC)

你可以在 console 或者 cli 模式下调用。

  • 在 console 模式下,Pocsuite3 模仿了 Metasploit 的操作模式,你只需要使用 set 命令来设置相应的参数,然后 run 或者 check 来执行(attackshell 命令也可以)。
  • 在 cli 模式下,如上面例子所示,定义了 usernamepassword 两个字段,你可以在参数后面加上 --username test --password test 来调用执行,需要注意的是,如果你的参数中包含了空格,用双引号 " 来包裹它。

支持的自定义字段类型

和上面类似,如果你想使用自定义的字段,将它定义到 _options 方法中,然后返回一个数组。Pocsuite3 支持的自定义字段类型如下:

from pocsuite3.api import OptString, OptDict, OptIP, OptPort, OptBool, OptInteger, OptFloat, OptItems
字段类型字段描述参数解释相关例子
OptString接收字符串类型参数default: 传入一个默认值
descript: 字段描述,默认为空
require: 是否必须,默认 False
OptDict接收一个字典类型参数,在选择上如果选择 key,调用时会调用对应的 valuedefault: 传入一个默认值
descript: 字段描述,默认为空
require: 是否必须,默认 False
OptIP接收 IP 类型的字符串default: 传入一个默认值
descript: 字段描述,默认为空
require: 是否必须,默认 False
OptPort接收端口类型参数default: 传入一个默认值
descript: 字段描述,默认为空
require: 是否必须,默认 False
OptBool接收布尔类型参数default: 传入一个默认值
descript: 字段描述,默认为空
require: 是否必须,默认 False
OptInteger接收整数类型参数default: 传入一个默认值
descript: 字段描述,默认为空
require: 是否必须,默认 False
OptFloat接收浮点数类型参数default: 传入一个默认值
descript: 字段描述,默认为空
require: 是否必须,默认 False
OptItems接收 list 类型参数default: 传入一个默认值
selectd: 默认选择
descript: 字段描述,默认为空
require: 是否必须,默认 False

需要注意的是,console 模式支持所有的参数类型,cli 模式除了OptDictOptBoolOptItems 类型外都支持。

Released under the GPLv2 License.