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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

java开发有日志存表的吗_Java日志信息存库(logback篇)

發(fā)布時(shí)間:2024/9/27 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java开发有日志存表的吗_Java日志信息存库(logback篇) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

一、Logback簡介

Logback是由log4j創(chuàng)始人設(shè)計(jì)的又一個(gè)開源日志組件。logback當(dāng)前分成三個(gè)模塊:logback-core,logback- classic和logback-access。logback-core是其它兩個(gè)模塊的基礎(chǔ)模塊。logback-classic是log4j的一個(gè) 改良版本。此外logback-classic完整實(shí)現(xiàn)SLF4J API使你可以很方便地更換成其它日志系統(tǒng)如log4j或JDK14 Logging。logback-access訪問模塊與Servlet容器集成提供通過Http來訪問日志的功能。

二、編寫背景

很不明白客戶為什么要求將日志信息寫入到數(shù)據(jù)庫中去,還要提供個(gè)頁面給系統(tǒng)使用人員查看相應(yīng)日志。作為一個(gè)業(yè)務(wù)人員真的就能看懂系統(tǒng)日志上報(bào)錯(cuò)信息是啥意思么,個(gè)人深表懷疑。沒辦法,作為一枚屌絲程序猿,需求下來了只能硬著頭皮去開發(fā)。

三、編寫目的

只相信一句話:好記性不如爛筆頭,何況我記性差到前一周寫的代碼到現(xiàn)在竟毫無印象的境地呢。

四、Java日志信息存庫詳細(xì)解決方案

1.開發(fā)環(huán)境說明

Eclipse+Tomcat6+JDK1.6+Oracle+logback1.1

2.Java日志存庫實(shí)現(xiàn)方案

(1)使用logback組件默認(rèn)的DBAppender類實(shí)現(xiàn)

最初需求下來的時(shí)候想著logback應(yīng)該有自己的寫數(shù)據(jù)庫的解決辦法,于是乎結(jié)合源碼及度娘終究還是找到了。在logback-classic-1.1.3.jar的ch/qos/logback/classic/db/script/路徑下找到了Oracle數(shù)據(jù)庫對(duì)應(yīng)的建表語句腳本oracle.sql,其建表語句如下所示:

--Logback: the reliable, generic, fast and flexible logging framework.--Copyright (C) 1999-2010, QOS.ch. All rights reserved.--

--See http://logback.qos.ch/license.html for the applicable licensing--conditions.

--This SQL script creates the required tables by ch.qos.logback.classic.db.DBAppender--

--It is intended for Oracle 9i, 10g and 11g databases. Tested on version 9.2,--10g and 11g.

--The following lines are useful in cleaning any previously existing tables

--drop TRIGGER logging_event_id_seq_trig;--drop SEQUENCE logging_event_id_seq;--drop table logging_event_property;--drop table logging_event_exception;--drop table logging_event;

CREATE SEQUENCE logging_event_id_seq MINVALUE 1 START WITH 1;CREATE TABLElogging_event

(

timestmpNUMBER(20) NOT NULL,

formatted_messageVARCHAR2(4000) NOT NULL,

logger_nameVARCHAR(254) NOT NULL,

level_stringVARCHAR(254) NOT NULL,

thread_nameVARCHAR(254),

reference_flagSMALLINT,

arg0VARCHAR(254),

arg1VARCHAR(254),

arg2VARCHAR(254),

arg3VARCHAR(254),

caller_filenameVARCHAR(254) NOT NULL,

caller_classVARCHAR(254) NOT NULL,

caller_methodVARCHAR(254) NOT NULL,

caller_lineCHAR(4) NOT NULL,

event_idNUMBER(10) PRIMARY KEY);--the / suffix may or may not be needed depending on your SQL Client--Some SQL Clients, e.g. SQuirrel SQL has trouble with the following--trigger creation command, while SQLPlus (the basic SQL Client which--ships with Oracle) has no trouble at all.

CREATE TRIGGERlogging_event_id_seq_trig

BEFOREINSERT ONlogging_eventFOREACH ROWBEGIN

SELECTlogging_event_id_seq.NEXTVALINTO:NEW.event_idFROMDUAL;END;/

CREATE TABLElogging_event_property

(

event_idNUMBER(10) NOT NULL,

mapped_keyVARCHAR2(254) NOT NULL,

mapped_valueVARCHAR2(1024),PRIMARY KEY(event_id, mapped_key),FOREIGN KEY (event_id) REFERENCESlogging_event(event_id)

);CREATE TABLElogging_event_exception

(

event_idNUMBER(10) NOT NULL,

iSMALLINT NOT NULL,

trace_lineVARCHAR2(254) NOT NULL,PRIMARY KEY(event_id, i),FOREIGN KEY (event_id) REFERENCESlogging_event(event_id)

);

該sql腳本共創(chuàng)建了3張表,一個(gè)序列和一個(gè)觸發(fā)器。其中主要日志信息記錄在logging_event中,觸發(fā)器是在logging_event數(shù)據(jù)新增時(shí),將創(chuàng)建的序列值賦值給logging_event表的event_id。

1)JDBC連接池方式

oracle.jdbc.driver.OracleDriver

jdbc:oracle:thin:@127.0.0.1:1521:orcl

tiger

123456

2) JNDI方式

A.Tomcat服務(wù)器安裝目錄/conf/server.xml配置JNDI信息

B.Spring配置文件applicationContext.xml配置JNDI信息

java:comp/env/jdbc/logging

C.logback.xml文件配置JNDI信息

?xml version="1.0" encoding="UTF-8" ?>

java:comp/env/jdbc/logging

注:對(duì)于JNDI的配置不熟悉的,可以去找度娘幫忙或參考JNDI官方文檔,本文不做細(xì)究。

(2)使用自定義DBAppender類實(shí)現(xiàn)

當(dāng)初按上述的配置輕輕松松實(shí)現(xiàn)了日志信息存庫,但天有不測風(fēng)云,完成后卻被告知客戶那邊任務(wù)觸發(fā)器不安全,禁用觸發(fā)器。得知此消息后心里仿佛有千萬只草泥馬飛奔而過,沒辦法只有繼續(xù)想著怎么去改造了。于是就只能去自定義個(gè)DBAppender了,既然是自定義就干脆把其他兩張表直接刪了,僅使用logging_event表,其表結(jié)構(gòu)如下:

字段名

中文說明

類型

為空

TIMESTMP

記錄時(shí)間

NUMBER(20)

N

FORMATTED_MESSAGE

格式化后的日志信息

CLOB

N

LOGGER_NAME

執(zhí)行記錄請(qǐng)求的logger

VARCHAR2(256)

N

LEVEL_STRING

日志級(jí)別

VARCHAR2(256)

N

THREAD_NAME

日志線程名

VARCHAR2(256)

Y

REFERENCE_FLAG

包含標(biāo)識(shí):1-MDC或上下文屬性;2-異常;3-均包含

INTEGER

Y

ARG0

參數(shù)1

VARCHAR2(256)

Y

ARG1

參數(shù)2

VARCHAR2(256)

Y

ARG2

參數(shù)3

VARCHAR2(256)

Y

ARG3

參數(shù)4

VARCHAR2(256)

Y

CALLER_FILENAME

文件名

VARCHAR2(256)

N

CALLER_CLASS

VARCHAR2(256)

N

CALLER_METHOD

方法名

VARCHAR2(256)

N

CALLER_LINE

行號(hào)

VARCHAR2(256)

N

EVENT_ID

主鍵ID

NUMBER(10)

N

注:這個(gè)表結(jié)構(gòu)與logback提供的默認(rèn)表結(jié)構(gòu)有細(xì)微差別,主要體現(xiàn)在字段類型上,由于FORMATTED_MESSAGE存儲(chǔ)的是詳細(xì)的日志信息,字段類型VARCHAR2(4000)無法存儲(chǔ)大文本信息,所以直接改造成了CLOB類型。

1)自定義DBAppender類(ATSDBAppender.java)

packagecom.hundsun.fund.ats.core.system.loggingevent.dao;importjava.lang.reflect.Method;importjava.sql.Connection;importjava.sql.PreparedStatement;importjava.sql.SQLException;importjava.util.HashMap;importjava.util.Map;import staticch.qos.logback.core.db.DBHelper.closeStatement;import staticch.qos.logback.core.db.DBHelper.closeConnection;importch.qos.logback.classic.db.DBHelper;importch.qos.logback.classic.db.names.DBNameResolver;importch.qos.logback.classic.db.names.DefaultDBNameResolver;importch.qos.logback.classic.spi.CallerData;importch.qos.logback.classic.spi.ILoggingEvent;importch.qos.logback.core.db.DBAppenderBase;public class ATSDBAppender extends DBAppenderBase{protectedString insertSQL;protected static finalMethod GET_GENERATED_KEYS_METHOD;privateDBNameResolver dbNameResolver;static final int TIMESTMP_INDEX = 1;static final int FORMATTED_MESSAGE_INDEX = 2;static final int LOGGER_NAME_INDEX = 3;static final int LEVEL_STRING_INDEX = 4;static final int THREAD_NAME_INDEX = 5;static final int REFERENCE_FLAG_INDEX = 6;static final int ARG0_INDEX = 7;static final int ARG1_INDEX = 8;static final int ARG2_INDEX = 9;static final int ARG3_INDEX = 10;static final int CALLER_FILENAME_INDEX = 11;static final int CALLER_CLASS_INDEX = 12;static final int CALLER_METHOD_INDEX = 13;static final int CALLER_LINE_INDEX = 14;static final int EVENT_ID_INDEX = 15;static final StackTraceElement EMPTY_CALLER_DATA =CallerData.naInstance();static{

Method getGeneratedKeysMethod;try{

getGeneratedKeysMethod= PreparedStatement.class.getMethod("getGeneratedKeys", (Class[]) null);

}catch(Exception ex) {

getGeneratedKeysMethod= null;

}

GET_GENERATED_KEYS_METHOD=getGeneratedKeysMethod;

}public voidsetDbNameResolver(DBNameResolver dbNameResolver) {this.dbNameResolver =dbNameResolver;

}

@Overridepublic voidstart() {if (dbNameResolver == null)

dbNameResolver= newDefaultDBNameResolver();

insertSQL=ATSSQLBuilder.buildInsertSQL(dbNameResolver);super.start();

}public voidappend(ILoggingEvent eventObject) {

Connection connection= null;

PreparedStatement insertStatement= null;try{

connection=connectionSource.getConnection();

connection.setAutoCommit(false);

insertStatement=connection.prepareStatement(getInsertSQL());synchronized (this) {

subAppend(eventObject, connection, insertStatement);

}

connection.commit();

}catch(Throwable sqle) {

addError("problem appending event", sqle);

}finally{

closeStatement(insertStatement);

closeConnection(connection);

}

}

@Overrideprotected void subAppend(ILoggingEvent event, Connection connection,PreparedStatement insertStatement) throwsThrowable {

bindLoggingEventWithInsertStatement(insertStatement, event);

bindLoggingEventArgumentsWithPreparedStatement(insertStatement, event.getArgumentArray());

bindCallerDataWithPreparedStatement(insertStatement, event.getCallerData());int updateCount =insertStatement.executeUpdate();if (updateCount != 1) {

addWarn("Failed to insert loggingEvent");

}

}protected voidsecondarySubAppend(ILoggingEvent event,

Connection connection,long eventId) throwsThrowable {

}voidbindLoggingEventWithInsertStatement(PreparedStatement stmt,

ILoggingEvent event)throwsSQLException {stmt.setLong(TIMESTMP_INDEX, event.getTimeStamp());

stmt.setString(FORMATTED_MESSAGE_INDEX, event.getFormattedMessage());

stmt.setString(LOGGER_NAME_INDEX, event.getLoggerName());

stmt.setString(LEVEL_STRING_INDEX, event.getLevel().toString());

stmt.setString(THREAD_NAME_INDEX, event.getThreadName());

stmt.setShort(REFERENCE_FLAG_INDEX, DBHelper.computeReferenceMask(event));

}voidbindLoggingEventArgumentsWithPreparedStatement(PreparedStatement stmt,

Object[] argArray)throwsSQLException {int arrayLen = argArray != null ? argArray.length : 0;for(int i = 0; i < arrayLen && i < 4; i++) {

stmt.setString(ARG0_INDEX+i, asStringTruncatedTo254(argArray[i]));

}if(arrayLen < 4) {for(int i = arrayLen; i < 4; i++) {

stmt.setString(ARG0_INDEX+i, null);

}

}

}

String asStringTruncatedTo254(Object o) {

String s= null;if(o != null) {

s=o.toString();

}if(s == null) {return null;

}if(s.length() <= 254) {returns;

}else{return s.substring(0, 254);

}

}voidbindCallerDataWithPreparedStatement(PreparedStatement stmt,

StackTraceElement[] callerDataArray)throwsSQLException {

StackTraceElement caller=extractFirstCaller(callerDataArray);

stmt.setString(CALLER_FILENAME_INDEX, caller.getFileName());

stmt.setString(CALLER_CLASS_INDEX, caller.getClassName());

stmt.setString(CALLER_METHOD_INDEX, caller.getMethodName());

stmt.setString(CALLER_LINE_INDEX, Integer.toString(caller.getLineNumber()));

}privateStackTraceElement extractFirstCaller(StackTraceElement[] callerDataArray) {

StackTraceElement caller=EMPTY_CALLER_DATA;if(hasAtLeastOneNonNullElement(callerDataArray))

caller= callerDataArray[0];returncaller;

}private booleanhasAtLeastOneNonNullElement(StackTraceElement[] callerDataArray) {return callerDataArray != null && callerDataArray.length > 0 && callerDataArray[0] != null;

}

MapmergePropertyMaps(ILoggingEvent event) {

Map mergedMap = new HashMap();

Map loggerContextMap =event.getLoggerContextVO().getPropertyMap();

Map mdcMap =event.getMDCPropertyMap();if (loggerContextMap != null) {

mergedMap.putAll(loggerContextMap);

}if (mdcMap != null) {

mergedMap.putAll(mdcMap);

}returnmergedMap;

}

@OverrideprotectedMethod getGeneratedKeysMethod() {returnGET_GENERATED_KEYS_METHOD;

}

@OverrideprotectedString getInsertSQL() {returninsertSQL;

}

}

2)自定義SQLBuilder類(ATSSQLBuilder.java)

packagecom.hundsun.fund.ats.core.system.loggingevent.dao;importch.qos.logback.classic.db.names.ColumnName;importch.qos.logback.classic.db.names.DBNameResolver;importch.qos.logback.classic.db.names.TableName;public classATSSQLBuilder {staticString buildInsertSQL(DBNameResolver dbNameResolver) {

StringBuilder sqlBuilder= new StringBuilder("INSERT INTO ");

sqlBuilder.append(dbNameResolver.getTableName(TableName.LOGGING_EVENT)).append(" (");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.TIMESTMP)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.FORMATTED_MESSAGE)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.LOGGER_NAME)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.LEVEL_STRING)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.THREAD_NAME)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.REFERENCE_FLAG)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.ARG0)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.ARG1)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.ARG2)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.ARG3)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.CALLER_FILENAME)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.CALLER_CLASS)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.CALLER_METHOD)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.CALLER_LINE)).append(", ");

sqlBuilder.append(dbNameResolver.getColumnName(ColumnName.EVENT_ID)).append(") ");

sqlBuilder.append("VALUES (?, ?, ? ,?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,LOGGING_EVENT_ID_SEQ.nextval)");returnsqlBuilder.toString();

}

}

注:類中LOGGING_EVENT_ID_SEQ序列需自行創(chuàng)建,logback默認(rèn)建表語句中有該序列的創(chuàng)建語句,直接拿來使用即可。

3)logback.xml配置

此時(shí)JDBC與JNDI方式配置只需要將原name為DB的appender標(biāo)簽class屬性的值指向自定義DBAppender即可,其他配置不變,下述代碼為JDBC配置示例:

oracle.jdbc.driver.OracleDriver

jdbc:oracle:thin:@127.0.0.1:1521:orcl

tiger

123456

(3)測試類的編寫

packagecom.hundsun.fund.ats.modules.server.test;importorg.slf4j.Logger;importorg.slf4j.LoggerFactory;public classLogbackTest {public static voidmain(String[] args) {//dblog為logback.xml中l(wèi)ogger標(biāo)簽name屬性的值

Logger logger= LoggerFactory.getLogger("dblog");

logger.debug("DEBUG級(jí)別信息");

logger.warn("WARN級(jí)別信息");

logger.info("INFO級(jí)別信息");

logger.error("ERROR級(jí)別信息");

}

}

五、總結(jié)

文中涉及到的Logback日志信息存庫的處理只是在源代碼的基礎(chǔ)上做了點(diǎn)小小的改動(dòng)而已,并非完整地介紹該組件的功能。想要全面學(xué)習(xí)Logback日志組件,請(qǐng)參考官方提供的源碼和相應(yīng)的API幫助文檔。

總結(jié)

以上是生活随笔為你收集整理的java开发有日志存表的吗_Java日志信息存库(logback篇)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

欧美一区日韩精品 | 国产我不卡 | 丁香六月婷婷开心 | 97av超碰| 久久99电影| 夜又临在线观看 | 91桃色在线播放 | 成人小视频在线 | 在线视频婷婷 | 成人久久综合 | 国产高潮久久 | 国产精品99久久久精品免费观看 | 精品久久久久久久久久久院品网 | 爱色婷婷| 美女黄频 | 99中文在线| 天天爽天天摸 | 91av视频播放 | 国偷自产中文字幕亚洲手机在线 | 国产精美视频 | 欧美一级免费高清 | www.夜夜夜 | 国产一级视频在线免费观看 | 丁香六月伊人 | 激情电影在线观看 | 狠狠久久综合 | 碰天天操天天 | 一区二区三区日韩在线观看 | 亚州国产精品视频 | www色网站 | 成人av播放 | 国产r级在线观看 | 国产精品久久久久久久久久新婚 | 又黄又爽又色无遮挡免费 | 久草在线高清视频 | 久草精品网 | 免费三级黄色片 | 久久精品视频观看 | 精品国产观看 | 五月天综合婷婷 | 久久国产日韩 | 国产精品www| 日日日视频 | 国产免费观看高清完整版 | 久久久蜜桃 | 在线 国产 亚洲 欧美 | 蜜桃视频日韩 | 日本韩国精品在线 | 又黄又爽又色无遮挡免费 | 久久中文精品视频 | 日韩精品中文字幕在线不卡尤物 | 日韩激情在线视频 | 精品在线一区二区三区 | 日韩四虎| 日本精品一 | 91麻豆精品国产91久久久更新时间 | 麻豆视频免费在线播放 | 日本最新中文字幕 | 精品国产成人av | 成片免费观看视频 | 狠狠干 狠狠操 | 欧美一级艳片视频免费观看 | 99在线高清视频在线播放 | 我要看黄色一级片 | 成人精品久久久 | 天堂av在线网址 | 天天伊人网 | 91看片网址| 国产精品99爱| 亚洲婷婷综合色高清在线 | 在线精品视频在线观看高清 | 五月激情丁香婷婷 | 精品999在线观看 | 久久国产网 | 亚洲一区二区精品 | 久久成人一区二区 | 欧美男男激情videos | 欧美激情精品久久久久久变态 | 毛片一二区 | 欧美一级网站 | 97色婷婷成人综合在线观看 | 久久精品国产免费看久久精品 | 色综合久久久久综合99 | 精品在线小视频 | 国产资源网 | 国产韩国日本高清视频 | 亚洲精品在线观看中文字幕 | 亚洲午夜精品久久久 | 亚洲在线 | 在线免费日韩 | 一级欧美日韩 | 免费观看久久 | 婷婷丁香色 | 在线免费av播放 | 亚洲伊人色 | 亚洲欧美日本一区二区三区 | 国产又粗又硬又爽的视频 | 亚洲综合视频网 | 麻豆一区在线观看 | 2022久久国产露脸精品国产 | 丁香高清视频在线看看 | 久久久精品国产免费观看同学 | 亚州精品国产 | 日韩久久精品一区二区三区 | 国产专区一 | 97在线免费观看视频 | 免费视频久久久 | 视频在线日韩 | 日韩免费视频在线观看 | 91在线视频免费91 | 日韩av在线小说 | 午夜国产影院 | 在线播放精品一区二区三区 | 婷婷久久五月天 | 久9在线 | 日日射av | 中文字幕在线网 | 在线观看免费一级片 | 99在线精品免费视频九九视 | 色91在线| 欧美夫妻性生活电影 | 在线亚洲精品 | 久久久久女人精品毛片九一 | 日韩在线观看你懂得 | 在线观看视频日韩 | 婷婷色网 | 国产福利资源 | 日日夜夜天天久久 | 奇米导航 | 国产一区在线看 | 久草视频在线资源 | 美女视频免费一区二区 | 国产精品1区 | 国产一区免费视频 | 婷婷成人在线 | 美女久久网站 | 在线视频 一区二区 | 亚洲午夜精品福利 | 久久精品久久久精品美女 | 久久久www成人免费精品张筱雨 | 免费日韩视频 | 欧美午夜a | bbbbb女女女女女bbbbb国产 | 啪啪动态视频 | 又黄又爽又刺激 | 久久影视网| 综合色播 | 国产精品乱看 | 国产精品一区二区三区在线看 | 久操伊人 | 91在线永久 | 久久久国产精品人人片99精片欧美一 | 亚洲专区中文字幕 | 麻豆精品视频在线观看免费 | 国产婷婷在线观看 | 欧洲亚洲女同hd | 亚洲资源在线观看 | 91视频这里只有精品 | 婷婷午夜 | 99免费国产| 手机av在线网站 | 国产不卡一二三区 | 国产精品门事件 | 成年人黄色在线观看 | 在线观看aa | 国产精品久久久99 | 精品久久久久久久久亚洲 | 久草视频99 | 丝袜av网站 | 日韩视频图片 | 手机在线观看国产精品 | 精品国产乱码一区二区三区在线 | 久久久亚洲麻豆日韩精品一区三区 | 99热这里只有精品在线观看 | 精品视频国产一区 | 久久久影院官网 | 99久久精品国产一区二区三区 | 黄色影院在线免费观看 | 黄色高清视频在线观看 | 五月花婷婷 | 天天做天天爱天天爽综合网 | 亚洲天堂社区 | 日本最大色倩网站www | 欧美性生活小视频 | 亚洲另类视频在线 | 日韩在线视频免费观看 | 亚洲综合涩 | 成人中心免费视频 | 亚洲一区美女视频在线观看免费 | 99精品一区二区 | 国产成人精品区 | 91精品视频免费观看 | 国产区在线视频 | 99精品视频观看 | 日韩av综合网站 | 日本午夜在线亚洲.国产 | 日韩毛片在线播放 | 久久99久久99免费视频 | 国产美女久久久 | 久久天天躁夜夜躁狠狠躁2022 | 欧美精品亚州精品 | 国产第一页在线播放 | 99免费看片 | 久久精品亚洲一区二区三区观看模式 | 91麻豆免费版 | 最新日韩视频 | 91精品国产99久久久久久久 | 成人九九视频 | 91在线观看视频网站 | 中文字幕 国产精品 | 久久国产精品一区二区 | 久久亚洲国产精品 | 日韩中文字幕在线不卡 | 国产高清在线一区 | 国产午夜视频在线观看 | 狠狠干夜夜爱 | 人人澡超碰碰97碰碰碰软件 | 国产一区在线视频播放 | 国产午夜精品一区 | 久久深夜福利免费观看 | 青青河边草观看完整版高清 | 亚洲精品tv久久久久久久久久 | 久久久影片 | 久久99热久久99精品 | 伊人影院av | 免费色视频网址 | 久久中文字幕在线视频 | 在线观看视频一区二区三区 | 91成年人视频 | 最近免费中文字幕 | 亚洲精品中文字幕在线 | 91精品免费在线观看 | 粉嫩av一区二区三区四区在线观看 | 中文字幕在线免费观看 | 人人爱人人爽 | 亚洲资源在线观看 | 日韩激情免费视频 | 五月婷婷综合激情网 | 久久九九影视 | 99久久99视频 | 国产黄在线看 | 日韩欧美高清不卡 | 最新av电影网址 | 国产精品视频永久免费播放 | 欧美性色综合网 | 亚洲一一在线 | 91热爆在线观看 | 91九色视频在线播放 | 99色亚洲 | 久久精品毛片 | 99视频精品免费观看, | 狠狠激情中文字幕 | 在线观看黄网 | 色一色在线 | 国产一级免费在线观看 | 亚洲精品视频观看 | 中文在线a∨在线 | 成人小视频在线免费观看 | 综合色久| 99久久激情视频 | 久久久久久久福利 | 色婷婷97| 中文字幕在线观看第一区 | 五月婷婷婷婷婷 | 99热精品在线 | 亚洲成人黄色av | 精品久久久久久亚洲 | 98福利在线| 91免费观看视频在线 | 91av在线不卡 | 天天射天天爱天天干 | 国产91精品在线观看 | 韩国av一区二区三区在线观看 | 日韩在线二区 | 久操视频在线观看 | 婷婷国产在线 | 国产aaa大片 | 五月天高清欧美mv | 欧美日韩在线电影 | 视频国产精品 | 在线观看日韩免费视频 | 黄色一及电影 | 亚洲更新最快 | 色婷婷综合五月 | 99久久精品免费 | 欧美另类亚洲 | 成人h电影在线观看 | 欧美另类tv | 久久这里只有精品久久 | 麻豆视频免费在线 | 国产精品va在线观看入 | 久久精品xxx | 欧美小视频在线观看 | 久 久久影院 | 国产视频精选 | 在线免费中文字幕 | 福利视频网址 | 91亚洲网 | 欧美性受极品xxxx喷水 | 色综合天天色 | 久久免费美女视频 | 精品亚洲午夜久久久久91 | 九九久久婷婷 | 婷久久| 久久er99热精品一区二区 | 欧美aa一级片 | 亚洲精品乱码久久久久久写真 | 免费 在线 中文 日本 | 狠狠婷婷| 日韩精品中文字幕久久臀 | 亚洲精品在线一区二区 | 久久久www成人免费毛片麻豆 | 国产欧美三级 | 久草在线资源观看 | 亚洲精品网址在线观看 | 成人免费观看大片 | 久久国产精品色婷婷 | av官网在线 | 国产18精品乱码免费看 | 日韩免费电影 | 久久免费视频1 | 免费日韩精品 | 久久精品香蕉 | 欧美一级网站 | 欧美a影视 | 黄色毛片视频免费观看中文 | 中文字幕在线看视频 | 亚洲免费观看在线视频 | 国产91粉嫩白浆在线观看 | 免费能看的av | 91亚洲国产成人久久精品网站 | 色999精品 | 一区二区三区四区五区在线视频 | 色噜噜日韩精品欧美一区二区 | 成人三级视频 | 91桃色免费视频 | 三级av网| 五月激情丁香 | 国产成人91 | 96超碰在线 | 欧美性色综合网 | 97影视 | 人人爱人人舔 | 亚洲一区 影院 | 天天综合天天做天天综合 | 在线免费观看视频一区 | 亚洲一区视频在线播放 | 91理论电影| 777视频在线观看 | 天天干天天操天天搞 | 婷婷5月激情5月 | 偷拍精品一区二区三区 | 手机看国产毛片 | 午夜精品久久久久久久99水蜜桃 | 亚洲 欧美日韩 国产 中文 | 国产无套视频 | 中文字幕日韩高清 | 国产91精品看黄网站在线观看动漫 | 四虎在线观看网址 | 中文字幕在线看视频 | 亚洲成av人电影 | 成人在线视频在线观看 | a级成人毛片 | 国产精品一区二区免费看 | 波多野结衣一区二区 | 国产在线精品一区二区不卡了 | 午夜精品久久一牛影视 | 欧美色综合天天久久综合精品 | 在线观看国产区 | 日韩在线理论 | 狠狠色综合网站久久久久久久 | 99r国产精品 | 欧美综合在线视频 | 三级av免费观看 | 亚洲aⅴ在线观看 | 丁香激情视频 | 91av视频在线免费观看 | 啪啪免费视频网站 | 6080yy精品一区二区三区 | 国产玖玖精品视频 | 国产一区在线免费观看 | 黄p在线播放 | 免费麻豆 | 国产精品一区二区三区免费看 | www.91av在线| 天天射色综合 | 精品91视频 | 久久久久久久久久久免费视频 | 麻豆视频在线观看免费 | 人人要人人澡人人爽人人dvd | 久久手机免费观看 | 狠狠干在线 | 波多野结衣电影一区 | 毛片网站在线 | 色播五月激情五月 | 国产不卡在线看 | 久久不见久久见免费影院 | 中文字幕在线观看视频网站 | 九九免费在线观看视频 | 青草视频在线免费 | 日日躁你夜夜躁你av蜜 | 亚洲成av人片| 午夜三级福利 | 国产精品九九热 | 精品久久中文 | 中文字幕丝袜制服 | 免费黄色网址网站 | 国产成人在线免费观看 | 久久久精品福利视频 | 欧美国产不卡 | 亚洲香蕉视频 | av先锋影音少妇 | 在线观看香蕉视频 | 色偷偷88888欧美精品久久久 | 久久精久久精 | 国产伦精品一区二区三区高清 | 亚洲午夜久久久久 | 热久久电影 | 国内精品久久久久久中文字幕 | 日韩一级电影在线 | 国产九色在线播放九色 | 99精品视频免费看 | 国产九九九精品视频 | 在线成人一区 | 狠狠干.com | 精品字幕在线 | 天天综合网 天天 | 色综合久久精品 | 国产在线污 | 欧美视频二区 | 国产96在线 | 欧美一区二区精美视频 | 久二影院 | www.xxxx欧美 | 美女天天操 | www.国产视频 | 日本中文在线观看 | 久久精品超碰 | 丝袜美腿在线播放 | 91丨九色丨勾搭 | 国产一区二区中文字幕 | 黄色最新网址 | 成人啊 v | 精品国产一区二区久久 | 黄p在线播放 | 国产精品99视频 | 91av视频网站| 91成人精品观看 | 国产亚洲精品福利 | 亚洲激情视频在线观看 | 国产高清一 | 国产精品美女视频 | 美国av片在线观看 | 国产馆在线播放 | 国产国语在线 | 欧美淫aaa免费观看 日韩激情免费视频 | 免费在线观看av网址 | 日韩成人免费在线观看 | 黄色软件在线观看视频 | 麻豆免费观看视频 | 亚洲视频免费在线 | 夜夜嗨av色一区二区不卡 | 中文字幕成人 | 久久久亚洲国产精品麻豆综合天堂 | 日韩成人免费在线电影 | 久久久精品国产一区二区三区 | 丁香色婷| 五月天亚洲激情 | 婷婷色网 | 国产精品久久久久久久99 | 日韩欧美综合视频 | 精品国精品自拍自在线 | 超级av在线 | 久草视频免费 | 亚洲三级黄色 | 日韩伦理一区二区三区av在线 | 成年人免费观看国产 | 色偷偷人人澡久久超碰69 | 一区二区三区在线观看免费视频 | 青青草国产精品 | 操操操操网 | 成人一区电影 | 久草香蕉在线 | 又黄又刺激又爽的视频 | 国产精品亚洲片在线播放 | 黄色app网站在线观看 | 免费看国产曰批40分钟 | 操操日日| 91c网站色版视频 | 日韩高清无线码2023 | 成人免费看片98欧美 | 欧美日韩高清免费 | 亚洲国产日韩欧美在线 | 国产丝袜制服在线 | 日日干天天射 | 亚洲精品乱码久久久久 | 在线观看国产一区二区 | 精品国产伦一区二区三区免费 | 国产高清在线免费 | 国产精品不卡在线播放 | 欧美成人基地 | 国产黄色一级片在线 | 欧美一区成人 | 久久久久久免费视频 | 欧美巨大| 国产精品涩涩屋www在线观看 | 亚洲色视频 | 国产99久久久久久免费看 | 伊人久久国产 | 97精品在线视频 | 国产精品9999久久久久仙踪林 | av片在线观看 | 亚洲人成精品久久久久 | 深夜福利视频在线观看 | www.亚洲精品| 久久久久久黄色 | 免费在线观看成人av | 高清免费在线视频 | 国产福利91精品一区二区三区 | 五月的婷婷 | 97超碰免费在线 | 国产婷婷视频在线 | 99精品久久久久 | 丁香九月激情综合 | 在线国产中文字幕 | 视频一区二区三区视频 | 手机av在线不卡 | 国产美女精品人人做人人爽 | 精品视频网站 | 久久久久久久久久免费视频 | 午夜久久精品 | 国产亚洲va综合人人澡精品 | 狠狠色香婷婷久久亚洲精品 | 国产精品国产三级国产专区53 | 99资源网 | 国产96在线视频 | 久久国产经典 | 麻豆视频国产在线观看 | 久久精品综合 | 久久久久久免费 | 99视频久久 | 午夜精品剧场 | 日本精品一区二区三区在线播放视频 | www.91国产 | 久久99精品国产99久久6尤 | 亚洲精品高清在线观看 | 狠狠干成人 | 在线观看成人小视频 | 最近乱久中文字幕 | 九九免费在线看完整版 | 91在线精品一区二区 | 免费在线播放 | 日本中文字幕影院 | 日韩最新av在线 | 日韩在线观看不卡 | 欧洲精品亚洲精品 | 91在线视频 | 国产色婷婷在线 | 怡春院av| 人人模人人爽 | 婷婷日| 人人艹视频 | 色综合久久久 | 欧美精品一区二区在线观看 | 操操操综合 | 尤物一区二区三区 | 国产日本亚洲 | 91精品国产高清自在线观看 | 久久免费高清 | 久久色中文字幕 | 五月花婷婷 | 日韩欧美国产精品 | 婷婷色网 | 免费视频在线观看网站 | 久久久国际精品 | 精品在线观看国产 | 亚洲综合小说电影qvod | 午夜精品成人一区二区三区 | 国产精品一区二区你懂的 | 99精品国产一区二区三区不卡 | 色av婷婷 | 天天色天天操天天爽 | 91探花在线 | 婷婷视频在线播放 | 久久久午夜精品理论片中文字幕 | 视频二区在线视频 | 精品久久久久久久久久久久 | 操综合 | 日本在线成人 | 久久不卡国产精品一区二区 | 日韩在线无 | 美腿丝袜av | 香蕉视频久久 | 波多野结衣在线观看一区二区三区 | 久久精品久久久久 | 久久综合狠狠综合 | 五月婷婷香蕉 | 日韩一级成人av | 欧美成人精品欧美一级乱黄 | 在线观看国产成人av片 | .国产精品成人自产拍在线观看6 | 国产精品18久久久久久不卡孕妇 | 人人看人人爱 | 色视频在线 | 不卡av电影在线 | 色婷婷狠狠五月综合天色拍 | 国产高清在线免费观看 | 国产精品日韩久久久久 | 婷婷综合国产 | 91av视频在线播放 | 婷婷在线视频观看 | 久久久久久久久久久影院 | 免费视频网 | 欧美精品久久久久久久久免 | 成人国产一区 | 国产在线专区 | 免费看污污视频的网站 | 91资源在线免费观看 | 久久综合九色综合欧美就去吻 | av播放在线 | 亚洲国产精品成人va在线观看 | 99视频在线免费 | 偷拍福利视频一区二区三区 | 91mv.cool在线观看 | 亚洲午夜久久久久久久久电影网 | 亚洲情婷婷 | 99精品免费久久久久久日本 | 国产亚洲资源 | 91久久一区二区 | 国内成人精品2018免费看 | 亚洲欧美成人网 | 99精品视频精品精品视频 | 亚在线播放中文视频 | 精品一区在线看 | 精品国产美女 | 欧美日韩一区二区视频在线观看 | 国产欧美久久久精品影院 | 91超级碰 | 99久久精品免费看 | 久久99国产精品视频 | 免费观看一区二区三区视频 | 日韩69av | 日日夜夜91 | 日日干网址 | 国产真实精品久久二三区 | a黄色| 激情丁香5月 | 天天干天天干天天操 | av在线播放中文字幕 | 中文字幕乱在线伦视频中文字幕乱码在线 | 黄色特级片 | 欧美一级高清片 | 日韩av一区二区三区在线观看 | 视频成人| 91禁在线观看 | 久热免费在线 | 亚洲精品动漫久久久久 | 亚洲人成人天堂h久久 | 青青河边草观看完整版高清 | 日韩av在线看 | 亚洲精品视频在线免费播放 | 天天干天天干天天干 | 西西444www | 国产高清永久免费 | 一级片视频在线 | 九九免费在线观看 | 日韩av电影中文字幕在线观看 | 久久久噜噜噜久久久 | 日韩色在线观看 | 色婷婷狠 | 99精品乱码国产在线观看 | 日韩免费一二三区 | japanesefreesex中国少妇 | 久久免费视频播放 | 久久综合五月婷婷 | 91成版人在线观看入口 | 亚洲精品乱码久久久久v最新版 | 日本一区二区免费在线观看 | 91成人午夜 | 亚洲视频久久 | 日韩伦理片一区二区三区 | 欧美精品在线观看 | 亚洲伊人成综合网 | 国产99久久九九精品免费 | 久久超碰免费 | 亚洲 欧美 91 | 日韩成年视频 | 中文字幕在线观看免费 | 中文字幕有码在线观看 | 国产剧在线观看片 | 五月天国产精品 | 亚洲乱码中文字幕综合 | 久久亚洲欧美日韩精品专区 | 国产区 在线 | 国产精品第一 | 国内精品久久久久影院男同志 | 久久与婷婷 | 99精品视频网 | 国产成人精品在线 | 97国产在线视频 | 手机av电影在线 | 伊人成人精品 | 999国产在线 | 国产成人av免费在线观看 | 欧美久久久久久久久久久 | 黄色大全视频 | 人成电影网 | 国产成人精品在线播放 | 91人人人| 精品久久久久久久久久久院品网 | 四虎影视成人永久免费观看视频 | 探花在线观看 | 91精品国 | 欧美男同网站 | 91插插插免费视频 | 香蕉影视app | 国产成人久久精品一区二区三区 | 免费在线观看午夜视频 | 视频在线91 | 久综合网 | 麻豆免费视频观看 | 超级碰碰碰视频 | 夜夜躁日日躁狠狠躁 | 久久久国产99久久国产一 | 亚洲aⅴ在线 | 婷婷六月网 | 91色国产在线 | 精品一区二区免费在线观看 | 麻豆视频一区 | 国产又粗又猛又黄 | 久久久久久久久爱 | 九九九九热精品免费视频点播观看 | 激情综合五月天 | 午夜精品久久久久 | 久久天堂网站 | www.久久久久 | 成人影视免费 | 91精品视频导航 | 嫩小bbbb摸bbb摸bbb| 亚洲精品福利视频 | 国产精品久久久亚洲 | 日日夜夜免费精品视频 | 97成人在线| 天天天综合 | 99精品热| 久久久精品国产一区二区电影四季 | 香蕉网站在线观看 | 九九久久精品视频 | 五月婷婷毛片 | 91免费试看 | 国产免费三级在线观看 | 国产香蕉97碰碰碰视频在线观看 | 六月丁香婷 | 天天视频亚洲 | 开心综合网 | 欧洲一区二区三区精品 | 天天综合网天天综合色 | 成人网在线免费视频 | 91精品视频在线观看免费 | 欧美激情精品久久久久久免费印度 | 久久精品国产美女 | 久久99亚洲网美利坚合众国 | av在线播放中文字幕 | 国产 字幕 制服 中文 在线 | 亚洲精品网站在线 | 成人啪啪18免费游戏链接 | 国产亚洲欧美精品久久久久久 | 天天爱天天色 | 成人中心免费视频 | 在线观看一二三区 | 免费成人在线视频网站 | av天天在线观看 | 久久婷婷视频 | 夜夜夜| 丁香久久综合 | 粉嫩av一区二区三区免费 | 国内精品视频久久 | 天天色天天操天天爽 | 午夜久久久久久久久久久 | 欧美天天综合 | 视频精品一区二区三区 | 久草在线免费新视频 | 久久久久国产成人精品亚洲午夜 | 免费成人在线观看 | 成人福利av | 小草av在线播放 | 国内一级片在线观看 | 国产夫妻性生活自拍 | 亚洲精品国产精品国 | 91在线影视 | 中文字幕电影一区 | 99热最新在线 | 中文字幕 国产视频 | 91人人爱 | 国产精品久久 | 在线天堂日本 | 国产麻豆视频免费观看 | 玖玖综合网 | 亚洲区另类春色综合小说 | 91亚洲国产成人 | 国产精品网站一区二区三区 | 玖玖999| 午夜精品久久久久久久久久久久久久 | 正在播放一区 | 99c视频高清免费观看 | 97视频人人免费看 | 久久久久久久久久久福利 | 久久久久国产一区二区 | 国产精品不卡av | 黄色在线免费观看网址 | 日韩大片在线免费观看 | 天堂av观看 | 亚洲国产综合在线 | 国产在线久久久 | 免费在线观看视频a | 久久久久免费精品国产小说色大师 | 日韩aa视频| 99爱视频在线观看 | 久久久www | 亚洲人人爱 | 九九九九免费视频 | 麻豆精品在线视频 | 日本爱爱免费 | 人人爱爱| 久久99精品国产99久久6尤 | 久久久久免费视频 | 97精品国产一二三产区 | 最近中文字幕免费av | 日韩在线观看第一页 | 天天操网站 | 日韩在线不卡 | 波多野结衣久久精品 | 亚洲日韩精品欧美一区二区 | 一级片免费视频 | 夜夜躁日日躁狠狠久久av | 黄网站免费大全入口 | 婷婷深爱五月 | 999久久久久久 | 天天操人人干 | 亚洲综合视频网 | 成人一区二区三区在线 | 国产精彩在线视频 | 成人手机在线视频 | 青青草国产成人99久久 | 中文字幕第 | 亚洲色影爱久久精品 | 久久精品人人做人人综合老师 | 日韩av不卡在线观看 | 操处女逼| 激情丁香在线 | 久久精品伊人 | 日韩中文字幕亚洲一区二区va在线 | 91视频链接| 在线视频 影院 | 色老板在线 | 久久综合导航 | 婷婷av在线 | 中文字幕 国产 一区 | 国产亚洲精品久久久久久久久久久久 | 天天射天天射天天 | 国产99久久久精品视频 | 久久黄色网页 | 美女福利视频网 | 久草手机视频 | 中文国产在线观看 | 国产流白浆高潮在线观看 | 国产视频资源在线观看 | 国产精品综合av一区二区国产馆 | 九色91av| 在线观看av网| free,性欧美| 在线观看视频h | 午夜av剧场 | 狠狠干夜夜操 | 日韩免费 | 999视频网| 97av色| 国产精品大片在线观看 | 狠狠夜夜 | 在线观看日本韩国电影 | 国产高清视频在线播放 | 成人黄色片免费看 | 久久手机免费观看 | 亚洲 欧美变态 另类 综合 | 亚洲人成人在线 | 日韩高清激情 | 九九视频在线观看视频6 | 精品一二三四五区 | 91精品一区二区三区久久久久久 | 久久99影院| 国产精品久久久久久爽爽爽 | 欧亚久久| 99热网站| 日日爽天天操 | 欧美日韩91 | 日本激情视频中文字幕 | 狠狠色丁香 | 午夜精品一区二区三区免费 | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 四虎国产精品成人免费影视 | 蜜桃av人人夜夜澡人人爽 | 国产精品成人一区 | 成年人免费在线观看网站 | 99久久精品免费看 | 97福利在线| 国产青春久久久国产毛片 | 丁香五月亚洲综合在线 | 久久精品一二区 | 日韩成人精品一区二区三区 | 日韩三级免费 | 国产高清网站 | 久久国产精品99久久久久久老狼 | www.干| 人人澡超碰碰97碰碰碰软件 | 久久伦理| 久久在线免费观看 | 国产精品网站一区二区三区 | 精品在线播放视频 | 福利av影院 | 日韩av资源站 | 97超视频 | 国产欧美综合视频 | 亚洲女欲精品久久久久久久18 | 在线观看日韩av | 69精品视频在线观看 | 成 人 黄 色 视频免费播放 | 欧美久久久久久久 | 亚洲a在线观看 | 夜夜躁狠狠躁日日躁视频黑人 | 9999在线视频 | 国产小视频在线观看免费 | 欧美性久久久久久 | 一区二区三区日韩视频在线观看 | 一区二区三区四区久久 | 啪啪动态视频 | 最近中文字幕mv免费高清在线 | 成人av网站在线观看 | 天天干人人 | 91最新地址永久入口 | 在线观影网站 | 四虎成人在线 | 久久久精品国产免费观看一区二区 | 国产精品手机视频 | 成人av网站在线观看 | 91av视频在线播放 | 亚州免费视频 | 亚洲午夜精品久久久久久久久久久久 | 91精品91| 国产一区二区三区免费视频 | 久久你懂得 | av中文在线 | www蜜桃视频| 99视频网站| 黄网站www| 日韩一区二区三区在线观看 | 久久av网 | 国产精品国产亚洲精品看不卡 | 99久久99 | 欧美在线99 | 97色免费视频 | 免费看片成年人 | 日本性久久 | 免费观看www小视频的软件 | av免费电影网站 | 在线观看黄色免费视频 | 欧洲亚洲女同hd | 国产成人高清 | 国产一区观看 | 天天综合成人网 | 91视频在线网址 | 精品字幕在线 | www.com操| 国产精品大全 | 伊人一级| 色婷婷久久久综合中文字幕 | 77国产精品 | 亚洲人成精品久久久久 | 日韩在线视频在线观看 | 国产精品久久久久影院日本 | 国内久久久 | 日韩精品中文字幕一区二区 | 91网页版免费观看 | 91桃色视频 | 欧美精品国产综合久久 | 免费高清在线一区 | 手机在线看a | 97国产超碰在线 | a级国产乱理论片在线观看 特级毛片在线观看 | 免费看的黄色录像 | 久人人| 西西444www大胆高清图片 | 丁香婷婷激情网 | 日韩v欧美v日本v亚洲v国产v | 成人黄色在线播放 | 午夜视频99 | aⅴ视频在线| 欧美激情va永久在线播放 | 精品视频在线观看 |