mirror of
https://github.com/sqlmapproject/sqlmap.git
synced 2024-11-29 13:03:50 +03:00
added support for setting HTTP method manualy
This commit is contained in:
parent
798ab4989b
commit
34a8cd75e3
|
@ -44,6 +44,7 @@ from lib.request.basic import forgeHeaders
|
||||||
from lib.request.basic import parseResponse
|
from lib.request.basic import parseResponse
|
||||||
from lib.request.direct import direct
|
from lib.request.direct import direct
|
||||||
from lib.request.comparison import comparison
|
from lib.request.comparison import comparison
|
||||||
|
from lib.request.methodrequest import MethodRequest
|
||||||
|
|
||||||
|
|
||||||
class Connect:
|
class Connect:
|
||||||
|
@ -71,6 +72,7 @@ class Connect:
|
||||||
url = kwargs.get('url', conf.url).replace(" ", "%20")
|
url = kwargs.get('url', conf.url).replace(" ", "%20")
|
||||||
get = kwargs.get('get', None)
|
get = kwargs.get('get', None)
|
||||||
post = kwargs.get('post', None)
|
post = kwargs.get('post', None)
|
||||||
|
method = kwargs.get('method', None)
|
||||||
cookie = kwargs.get('cookie', None)
|
cookie = kwargs.get('cookie', None)
|
||||||
ua = kwargs.get('ua', None)
|
ua = kwargs.get('ua', None)
|
||||||
direct = kwargs.get('direct', False)
|
direct = kwargs.get('direct', False)
|
||||||
|
@ -127,7 +129,12 @@ class Connect:
|
||||||
|
|
||||||
# Perform HTTP request
|
# Perform HTTP request
|
||||||
headers = forgeHeaders(cookie, ua)
|
headers = forgeHeaders(cookie, ua)
|
||||||
req = urllib2.Request(url, post, headers)
|
|
||||||
|
if method:
|
||||||
|
req = MethodRequest(url, post, headers)
|
||||||
|
req.set_method(method)
|
||||||
|
else:
|
||||||
|
req = urllib2.Request(url, post, headers)
|
||||||
|
|
||||||
if not req.has_header("Accept-Encoding"):
|
if not req.has_header("Accept-Encoding"):
|
||||||
requestHeaders += "Accept-Encoding: identity\n"
|
requestHeaders += "Accept-Encoding: identity\n"
|
||||||
|
|
32
lib/request/methodrequest.py
Normal file
32
lib/request/methodrequest.py
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
$Id$
|
||||||
|
|
||||||
|
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
||||||
|
|
||||||
|
Copyright (c) 2010 Miroslav Stampar <miroslav.stampar@gmail.com>
|
||||||
|
|
||||||
|
sqlmap is free software; you can redistribute it and/or modify it under
|
||||||
|
the terms of the GNU General Public License as published by the Free
|
||||||
|
Software Foundation version 2 of the License.
|
||||||
|
|
||||||
|
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
||||||
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
||||||
|
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
||||||
|
details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License along
|
||||||
|
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
||||||
|
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
"""
|
||||||
|
|
||||||
|
import urllib2
|
||||||
|
|
||||||
|
|
||||||
|
class MethodRequest(urllib2.Request):
|
||||||
|
''' Used to create HEAD/PUT/DELETE/... requests with urllib2 '''
|
||||||
|
def set_method(self, method):
|
||||||
|
self.method = method.upper()
|
||||||
|
def get_method(self):
|
||||||
|
return getattr(self, 'method', urllib2.Request.get_method(self))
|
Loading…
Reference in New Issue
Block a user