-
Notifications
You must be signed in to change notification settings - Fork 476
/
dynamicjs.py
70 lines (58 loc) · 2.19 KB
/
dynamicjs.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
#!/usr/bin/python
# by m4ll0k (@m4ll0k2)
# github.com/m4ll0k
import requests
import sys
import argparse
def Process(url:str)-> None:
headers = {}
if args.headers != "":
for header in args.headers.split(','):
h = header.split(':')
headers[h[0]] = h[1]
if args.cookies != "":
headers['Cookie'] = args.cookies
headers['User-Agent'] = 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/42.0.2311.135 Safari/537.36 Edge/12.246'
try:
req1 = requests.get(
url = url,
headers = headers
)
req2 = requests.get(
url = url,
headers = headers
)
if req1.status_code == req2.status_code:
if req1.content != req2.content:
print('[ + ] Dynamic js file: %s with %s status code'%(req1.url,req1.status_code))
except Exception as err:
print('[ E ] %s'%err)
def main():
pass
if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument('-i','--input',help="input js file, e.g: target1/main.js,target1/main2.js,..",action="store",default="")
parser.add_argument('-s','--stdin',help="get stdin input",action="store_true",default=False)
parser.add_argument('-c','--cookies',help="set cookie",action="store",default="")
parser.add_argument('-H','--headers',help="set headers, e.g: \"name:value;name:value\"",action="store",default="")
args = parser.parse_args()
if args.input == "" and args.stdin is False:
sys.exit(
print('[ + ] python3 %s -h'%sys.argv[0])
)
else:
targets = []
if args.input and args.stdin is False:
targets.extend(args.input.split(','))
elif args.stdin is True:
for target in sys.stdin.readlines():
target = target.strip()
if target == '\n':
sys.exit(
print('[ + ] python3 %s -h'%sys.argv[0])
)
else:
targets.append(target)
for target in targets:
print('[ + ] URL: %s'%target)
Process(target)