-
Notifications
You must be signed in to change notification settings - Fork 60
/
Copy pathfilescan.py
189 lines (170 loc) · 5.85 KB
/
filescan.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
187
188
189
#-*- coding:utf-8 -*-
# Author: Mosuan
# Website: http://www.0aa.me
# 备份目录文件扫描 tar zip .git .svn ...
import re
import sys
import time
import logging
import urlparse
import threading
from reque import Reque
from rule_parse import Rule
from backup_rule import backup_rule
FORMAT = '%(asctime)-15s %(message)s'
logging.basicConfig(format=FORMAT)
logger = logging.getLogger('filescan')
logo = """
_ _ _
__(.)< __(.)> __(.)=
\___) \___) \___)
_ _ _ Author: Mosuan
__(.)< __(.)> __(.)= Blog: http://www.0aa.me
\___) \___) \___) Version: FileScan v1
"""
print(logo)
class FileScan(object):
def __init__(self):
# 最终结果
self.result = []
def _data(self, item):
"""
验证
"""
rule_true = item.get("rule_true", "")
rule_result = item.get("result", "")
rule_true_status = self._check(rule_true, rule_result)
# 判断真规则是否存在
if rule_true_status:
# 读取假规则
rule_false = item.get("rule_false", "")
# 判断假规则
rule_false_status = self._check(rule_false, rule_result)
logger.warning('[FileScan] url: {} 正在进行二次验证是否存在信息泄露'.format(rule_true))
# 如果验证失败 说明存在漏洞
if not rule_false_status:
self.result.append(rule_true)
logger.warning('[FileScan Done] url: {} 存在信息泄露'.format(rule_true))
def _check(self, url, result):
"""
发送请求
"""
logger.warning('[FileScan] url: {}'.format(url))
response = Reque(url).query(url)
if response != None:
num = len(result)
check = []
length = result.get("length", "")
status_code = result.get("status_code", "")
header = result.get("header",{})
reg = result.get("reg", [])
#
if length:
check.append(self._length(response.content, length))
if reg:
check.append(self._reg(response.content, reg))
if status_code:
check.append(self._status_code(response.status_code, status_code))
if header:
check.append(self._header(response.headers, header))
is_check = [num for x in range(0,len(check)) if check[x]]
# 说明可能存在
if len(is_check) == num:
# 判断是否存在黑名单
_is = self._black_list(response)
if not _is:
return True
return False
def _status_code(self, code, result):
"""
判断响应状态
"""
if isinstance(result, list):
for num,status_code in enumerate(result):
if status_code == code:
return True
return False
def _length(self, content, result):
"""
判断文件大小
"""
if len(content) > result:
return True
return False
def _reg(self, content, result):
"""
判断回显内容
"""
if isinstance(result, list):
for num,reg in enumerate(result):
if len(re.findall(reg.lower(), content.lower())) > 0:
return True
return False
def _header(self, header, result):
"""
判断header
"""
if isinstance(result, dict):
for item in result:
_rule = result[item]
if isinstance(_rule, basestring):
_rule = list(_rule)
for num,reg in enumerate(_rule):
if len(re.findall(reg, header.get(item,""))) > 0:
return True
return False
def _black_list(self, response):
"""
黑名单判断
"""
_black = backup_rule.get("balcklist",{})
if _black:
black_html = _black.get("html",[])
if black_html:
for num,str in enumerate(black_html):
if len(re.findall(str.lower(), response.content.lower())) > 0:
return True
return False
def _warning(self, url):
host_list = ["gov.cn", "edu.cn"]
parse = urlparse.urlparse(url)
domain = parse.netloc.split(".")
hostname = domain[-2]+"."+domain[-1]
for num,host in enumerate(host_list):
if host == hostname:
return False
return True
def _data_print(self):
"""
在这里处理返回数据
本来想写敏感文件的,想了想,文件不就是信息吗..
"""
if not self.result:
print("没有扫到敏感信息泄露")
else:
for num,url in enumerate(self.result):
print("[**] url:{} 存在敏感信息泄露".format(url))
def main(self, url):
logging.info("正在测试url:{}".format(url))
if not self._warning(url):
print("\n[ Warning ] 你真的是在作死啊年轻人。请勿扫描不属于自己的网站!!!尤其是政府机关的网站!!!\n")
return
start_time = int(time.time())
result = Rule(url)._main()
for item in result:
search_t = threading.Thread(target=self._data, args=(item,))
search_t.setDaemon(True)
search_t.start()
# 这里建议调成 0.05 左右,不然很多网站来不及响应
time.sleep(0.02)
end_time = int(time.time())
print("\n耗时: {}秒".format(end_time - start_time))
# 存在则输出数据
self._data_print()
if __name__ == '__main__':
url = sys.argv[1]
if url:
obj = FileScan()
obj.main(url)
else:
print("没有url扫个**")