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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

VC++ OLE DB 读写数据库

發布時間:2024/1/1 c/c++ 57 豆豆
生活随笔 收集整理的這篇文章主要介紹了 VC++ OLE DB 读写数据库 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在需要對數據庫進行操作時,OLE DB總是被認為是一種效率最高但最難的方法。但是以我最近使用OLE DB的經驗看來,OLE DB的效率高則高矣,但卻一點都不難。說它難恐怕主要是因為可參考的中文資料太少,為了幫助以后需要接觸OLE DB的同行,我撰寫了這篇文章。本文包含如下內容:

  • OLE DB寫數據庫;
  • OLE DB讀數據庫;
  • OLE DB對二進制數據(text、ntext、image等)的處理。
  • 首先來看看對SQL Server進行寫操作的代碼,有一定VC基礎的讀者應該可以很順利地看懂。OLE DB寫數據庫,就是這么簡單!

    注:
    1.以下代碼中使用的模板類EAutoReleasePtr與ATL中的CComPtr類似,是一個在析構時自動調用Release的類。CComPtr的代碼在ATLBASE.H中定義。
    2.以下代碼均在UNICODE環境下編譯,因為執行的SQL語句必須是UNICODE的。設置工程為UNICODE的方法是:首先在project->settings->C/C++的屬性頁中的Preprocessor中,刪除_MBCS寫入UNICODE,_UNICODE。然后在link屬性頁中Category中選擇output,在Entry-Point symbol 中添加wWinMainCRTStartup。

    EAutoReleasePtr pIDBInitialize;
    HRESULT hResult = ConnectDatabase( &pIDBInitialize, _T(“127.0.0.1”), _T(“sa”), _T(“password”) );
    if( FAILED( hResult ) )
    {
    //失敗,可能是因為數據庫沒有啟動、用戶名密碼錯等等
    return;
    }

    EAutoReleasePtr pIOpenRowset;
    hResult = CreateSession( pIDBInitialize, &pIOpenRowset );
    if( FAILED( hResult ) )
    {
    //出錯
    return;
    }

    EAutoReleasePtr pICommand;
    EAutoReleasePtr pICommandText;
    hResult = CreateCommand( pIOpenRowset, &pICommand, &pICommandText );
    if( FAILED( hResult ) )
    {
    //出錯
    return;
    }

    hResult = ExecuteSQL( pICommand, pICommandText, _T(“USE PBDATA”) );
    if( FAILED( hResult ) )
    {
    //如果這里失敗,那就是SQL語句執行失敗。在此處,就是PBDATA還未創建
    return;
    }

    // 創建表
    ExecuteSQL( pICommand, pICommandText, _T(“CREATE TABLE 2005_1(Volume real NOT NULL,ID int NOT NULL IDENTITY)”) );

    // 添加記錄
    ExecuteSQL( pICommand, pICommandText, _T(“INSERT INTO 2005_1 VALUES(100.0)”) );

    //…

    其中幾個函數的代碼如下:

    HRESULT ConnectDatabase( IDBInitialize** ppIDBInitialize, LPCTSTR pszDataSource, LPCTSTR pszUserID, LPCTSTR pszPassword )
    {
    ASSERT( ppIDBInitialize != NULL && pszDataSource != NULL && pszUserID != NULL && pszPassword != NULL );

    UINT uTimeout = 15U; // 連接數據庫超時(秒) TCHAR szInitStr[1024]; VERIFY( 1023 >= wsprintf( szInitStr, _T("Provider=SQLOLEDB;Data Source=%s;Initial Catalog=master;User Id=%s;Password=%s;Connect Timeout=%u"), pszDataSource, pszUserID, pszPassword, uTimeout ) ); //Initial Catalog=master指明連接成功后,"USE master"。EAutoReleasePtr<IDataInitialize> pIDataInitialize; HRESULT hResult = ::CoCreateInstance( CLSID_MSDAINITIALIZE, NULL, CLSCTX_INPROC_SERVER,IID_IDataInitialize, ( void** )&pIDataInitialize ); if( FAILED( hResult ) ) {return hResult; }EAutoReleasePtr<IDBInitialize> pIDBInitialize; hResult = pIDataInitialize->GetDataSource( NULL, CLSCTX_INPROC_SERVER, ( LPCOLESTR )szInitStr,IID_IDBInitialize, ( IUnknown** )&pIDBInitialize ); if( FAILED( hResult ) ) {return hResult; } hResult = pIDBInitialize->Initialize( ); if( FAILED( hResult ) ) {return hResult; } * ppIDBInitialize = pIDBInitialize.Detach( ); return S_OK;

    }

    HRESULT CreateSession( IDBInitialize* pIDBInitialize, IOpenRowset** ppIOpenRowset )
    {
    ASSERT( pIDBInitialize != NULL && ppIOpenRowset != NULL );
    EAutoReleasePtr pSession;
    HRESULT hResult = pIDBInitialize->QueryInterface( IID_IDBCreateSession, ( void** )&pSession );
    if( FAILED( hResult ) )
    {
    return hResult;
    }
    EAutoReleasePtr pIOpenRowset;
    hResult = pSession->CreateSession( NULL, IID_IOpenRowset, ( IUnknown** )&pIOpenRowset );
    if( FAILED( hResult ) )
    {
    return hResult;
    }
    * ppIOpenRowset = pIOpenRowset.Detach( );
    return S_OK;
    }

    HRESULT CreateCommand( IOpenRowset* pIOpenRowset, ICommand** ppICommand, ICommandText** ppICommandText )
    {
    ASSERT( pIOpenRowset != NULL && ppICommand != NULL && ppICommandText != NULL );
    HRESULT hResult;
    EAutoReleasePtr pICommand;
    {
    EAutoReleasePtr pICreateCommand;
    hResult = pIOpenRowset->QueryInterface( IID_IDBCreateCommand, ( void** )&pICreateCommand );
    if( FAILED( hResult ) )
    {
    return hResult;
    }

    hResult = pICreateCommand->CreateCommand( NULL, IID_ICommand, (IUnknown**)&pICommand );if( FAILED( hResult ) ){return hResult;} } EAutoReleasePtr<ICommandText> pICommandText; hResult = pICommand->QueryInterface( &pICommandText ); if( FAILED( hResult ) ) {return hResult; } * ppICommand = pICommand.Detach( ); * ppICommandText = pICommandText.Detach( ); return S_OK;

    }

    HRESULT ExecuteSQL( ICommand* pICommand, ICommandText* pICommandText, LPCTSTR pszCommand, LONG* plRowsAffected )
    {
    ASSERT( pICommand != NULL && pICommandText != NULL && pszCommand != NULL && pszCommand[0] != 0 );

    HRESULT hResult = pICommandText->SetCommandText( DBGUID_DBSQL, ( LPCOLESTR )pszCommand ); if( FAILED( hResult ) ) {return hResult; } LONG lAffected; hResult = pICommand->Execute( NULL, IID_NULL, NULL, plRowsAffected == NULL ? &lAffected : plRowsAffected, ( IUnknown** )NULL ); return hResult;

    }

    以上就是寫數據庫的全部代碼了,是不是很簡單呢?下面再來讀的。

    // 先用與上面代碼中一樣的步驟獲取pICommand,pICommandText。此處省略

    HRESULT hResult = pICommandText->SetCommandText( DBGUID_DBSQL, ( LPCOLESTR )_T(“SELECT Volume FROM 2005_1 WHERE ID = @@IDENTITY”) ); //取我們剛剛添加的那一條記錄
    if( FAILED( hResult ) )
    {
    return;
    }

    LONG lAffected;
    EAutoReleasePtr pIRowset;
    hResult = pICommand->Execute( NULL, IID_IRowset, NULL, &lAffected, ( IUnknown** )&pIRowset );

    if( FAILED( hResult ) )
    {
    return;
    }

    EAutoReleasePtr pIAccessor;
    hResult = pIRowset->QueryInterface( IID_IAccessor, ( void** )&pIAccessor );

    if( FAILED( hResult ) )
    {
    return;
    }

    // 一個根據表中各字段的數值類型而定義的結構,用于存儲返回的各字段的值
    struct CLoadLastFromDB
    {
    DBSTATUS dwdsVolume;
    DWORD dwLenVolume;
    float fVolume;
    };

    // 此處我們只查詢了一個字段。如果要查詢多個字段,CLoadLastFromDB中要添加相應的字段定義,下面的dbBinding也要相應擴充。dbBinding[].iOrdinal要分別指向各個字段,dbBinding[].wType要根據字段類型賦合適的值。

    DBBINDING dbBinding[1];
    dbBinding[0].iOrdinal = 1; // Volume 字段的位置,從 1 開始
    dbBinding[0].obValue = offsetof( CLoadLastFromDB, fVolume );
    dbBinding[0].obLength = offsetof( CLoadLastFromDB, dwLenVolume );
    dbBinding[0].obStatus = offsetof( CLoadLastFromDB, dwdsVolume );
    dbBinding[0].pTypeInfo = NULL;
    dbBinding[0].pObject = NULL;
    dbBinding[0].pBindExt = NULL;
    dbBinding[0].dwPart = DBPART_VALUE | DBPART_STATUS | DBPART_LENGTH;
    dbBinding[0].dwMemOwner = DBMEMOWNER_CLIENTOWNED;
    dbBinding[0].eParamIO = DBPARAMIO_NOTPARAM;
    dbBinding[0].cbMaxLen = 0;
    dbBinding[0].dwFlags = 0;
    dbBinding[0].wType = DBTYPE_R4; // float就是DBTYPE_R4,int就是DBTYPE_I4。參見MSDN
    dbBinding[0].bPrecision = 0;
    dbBinding[0].bScale = 0;

    HACCESSOR hAccessor = DB_NULL_HACCESSOR;
    DBBINDSTATUS dbs[1];
    hResult = pIAccessor->CreateAccessor( DBACCESSOR_ROWDATA, 1, dbBinding, sizeof( CLoadLastDataFromDB ), &hAccessor, dbs );

    if( FAILED( hResult ) )
    {
    return;
    }

    ASSERT( dbs[0] == DBBINDSTATUS_OK );
    ULONG uRowsObtained = 0;
    HROW hRows[1]; // 這里我們只查詢了最新的那一條記錄
    HROW* phRows = hRows;
    CLoadLastFromDB rmd;
    hResult = pIRowset->GetNextRows( NULL, 0, 1, &uRowsObtained, &phRows );
    if( SUCCEEDED( hResult ) && uRowsObtained != 0U )
    {
    hResult = pIRowset->GetData( phRows[0], hAccessor, &rmd );
    if( FAILED( hResult ) )
    {
    ASSERT( FALSE );
    }
    ASSERT( rmd.dwdsVolume == DBSTATUS_S_OK );
    // rmd.fVolume 就是我們要取的值
    }

    pIRowset->ReleaseRows( uRowsObtained, phRows, NULL, NULL, NULL );
    pIAccessor->ReleaseAccessor( hAccessor, NULL );
    pIAccessor.Release( );
    pIRowset.Release( );

    讀操作也完成了,是不是仍然很簡單呢?下面我們再來看看最麻煩的二進制數據(text、ntext、image等)的讀寫。要實現BLOB數據的讀寫,我們需要一個輔助的類,定義如下:

    class CSequentialStream : public ISequentialStream // BLOB 數據訪問類
    {
    public:
    CSequentialStream( );
    virtual ~CSequentialStream( );
    virtual BOOL Seek( ULONG uPosition );
    virtual BOOL Clear( );
    virtual ULONG GetLength( ) { return m_uBufferUsed; };
    virtual operator void* const( ) { return m_pBuffer; };
    STDMETHODIMP_( ULONG ) AddRef( ) { return ++ m_uRefCount; };
    STDMETHODIMP_( ULONG ) Release( ) { ASSERT( m_uRefCount != 0U ); – m_uRefCount; if( m_uRefCount == 0U ) { delete this; } return m_uRefCount; };
    STDMETHODIMP QueryInterface( REFIID riid, LPVOID* ppv );
    STDMETHODIMP Read( void __RPC_FAR* pv, ULONG cb, ULONG __RPC_FAR* pcbRead );
    STDMETHODIMP Write( const void __RPC_FAR* pv, ULONG cb, ULONG __RPC_FAR* pcbWritten );
    void ResetPosition( ) { m_uPosition = 0U; };
    HRESULT PreAllocBuffer( ULONG uSize );

    private:
    ULONG m_uRefCount; // reference count
    void* m_pBuffer; // buffer
    ULONG m_uBufferUsed; // buffer used
    ULONG m_uBufferSize; // buffer size
    ULONG m_uPosition; // current index position in the buffer
    };

    實現如下:

    CSequentialStream::CSequentialStream( ) : m_uRefCount( 0U ), m_pBuffer( NULL ), m_uBufferUsed( 0U ), m_uBufferSize( 0U ), m_uPosition( 0U )
    {
    AddRef( );
    }

    CSequentialStream::~CSequentialStream( )
    {
    Clear( );
    }

    HRESULT CSequentialStream::QueryInterface( REFIID riid, void** ppv )
    {
    if( riid == IID_IUnknown || riid == IID_ISequentialStream )
    {
    * ppv = this;
    ( ( IUnknown* )*ppv )->AddRef( );
    return S_OK;
    }
    * ppv = NULL;
    return E_NOINTERFACE;
    }

    BOOL CSequentialStream::Seek( ULONG uPosition )
    {
    ASSERT( uPosition < m_uBufferUsed );
    m_uPosition = uPosition;
    return TRUE;
    }

    BOOL CSequentialStream::Clear( )
    {
    m_uBufferUsed = 0U;
    m_uBufferSize = 0U;
    m_uPosition = 0U;
    ( m_pBuffer != NULL ? CoTaskMemFree( m_pBuffer ) : 0 );
    m_pBuffer = NULL;
    return TRUE;
    }

    HRESULT CSequentialStream::PreAllocBuffer( ULONG uSize )
    {
    if( m_uBufferSize < uSize )
    {
    m_uBufferSize = uSize;
    m_pBuffer = CoTaskMemRealloc( m_pBuffer, m_uBufferSize );
    if( m_pBuffer == NULL )
    {
    Clear( );
    return STG_E_INSUFFICIENTMEMORY;
    }
    }
    return S_OK;
    }

    HRESULT CSequentialStream::Read( void* pv, ULONG cb, ULONG* pcbRead )
    {
    ( pcbRead != NULL ? ( * pcbRead = 0U ) : 0 );
    if( pv == NULL ) { return STG_E_INVALIDPOINTER; }
    if( cb == 0U ) { return S_OK; }

    ASSERT( m_uPosition <= m_uBufferUsed ); ULONG uBytesLeft = m_uBufferUsed - m_uPosition;if( uBytesLeft == 0U ) { return S_FALSE; } //no more bytesULONG uBytesRead = ( cb > uBytesLeft ? uBytesLeft : cb ); memcpy( pv, ( BYTE* )m_pBuffer + m_uPosition, uBytesRead ); m_uPosition += uBytesRead;( pcbRead != NULL ? ( * pcbRead = uBytesRead ) : 0 ); return ( cb != uBytesRead ? S_FALSE : S_OK );

    }

    HRESULT CSequentialStream::Write( const void* pv, ULONG cb, ULONG* pcbWritten )
    {
    if( pv == NULL ) { return STG_E_INVALIDPOINTER; }
    ( pcbWritten != NULL ? ( * pcbWritten = 0U ) : 0 );
    if( cb == 0U ){ return S_OK; }

    ASSERT( m_uPosition <= m_uBufferUsed ); if( m_uBufferSize < m_uPosition + cb ) {m_uBufferSize = m_uPosition + cb;m_pBuffer = CoTaskMemRealloc( m_pBuffer, m_uBufferSize );if( m_pBuffer == NULL ){Clear( );return STG_E_INSUFFICIENTMEMORY;} } m_uBufferUsed = m_uPosition + cb; memcpy( ( BYTE* )m_pBuffer + m_uPosition, pv, cb ); m_uPosition += cb; ( pcbWritten != NULL ? ( * pcbWritten = cb ) : 0 ); return S_OK;

    }

    下面我們開始往一個包含ntext字段的表中添加記錄。假設這個表(News)的結構為:ID int NOT NULL IDENTITY、Title nchar(80)、 Contents ntext。

    // 先將記錄添加進去,ntext字段留空。我們稍后再更新ntext的內容。
    HRESULT hResult = ExecuteSQL( pICommand, pICommandText, _T(“INSERT INTO News VALUES(’‘TEST’’,’’’’)”) );

    DBPROP dbProp;
    dbPropSet.guidPropertySet = DBPROPSET_ROWSET;
    dbPropSet.cProperties = 1;
    dbPropSet.rgProperties = &dbProp;

    DBPROPSET dbPropSet;
    dbPropSet.rgProperties[0].dwPropertyID = DBPROP_UPDATABILITY;
    dbPropSet.rgProperties[0].dwOptions = DBPROPOPTIONS_REQUIRED;
    dbPropSet.rgProperties[0].dwStatus = DBPROPSTATUS_OK;
    dbPropSet.rgProperties[0].colid = DB_NULLID;
    dbPropSet.rgProperties[0].vValue.vt = VT_I4;
    V_I4( &dbPropSet.rgProperties[0].vValue ) = DBPROPVAL_UP_CHANGE;

    EAutoReleasePtr pICommandProperties;
    hResult = pICommandText->QueryInterface( IID_ICommandProperties, ( void** )&pICommandProperties );

    // 設置 Rowset 屬性為“可以更新某字段的值”
    hResult = pICommandProperties->SetProperties( 1, &dbPropSet );

    hResult = pICommandText->SetCommandText( DBGUID_DBSQL, ( LPCOLESTR )L"SELECT Contents FROM News WHERE ID = @@IDENTITY" );

    LONG lAffected;
    EAutoReleasePtr pIRowsetChange;
    hResult = pICommand->Execute( NULL, IID_IRowsetChange, NULL, &lAffected, ( IUnknown** )&pIRowsetChange );

    EAutoReleasePtr pIAccessor;
    hResult = pIRowsetChange->QueryInterface( IID_IAccessor, ( void** )&pIAccessor );

    struct BLOBDATA
    {
    DBSTATUS dwStatus;
    DWORD dwLength;
    ISequentialStream* pISeqStream;
    };

    // 有關DBOBJECT、DBBINDING的設置,建議參考MSDN,很容易懂。
    DBOBJECT dbObj;
    dbObj.dwFlags = STGM_READ;
    dbObj.iid = IID_ISequentialStream;

    DBBINDING dbBinding;
    dbBinding.iOrdinal = 1; // BLOB 字段的位置,從 1 開始
    dbBinding.obValue = offsetof( BLOBDATA, pISeqStream );
    dbBinding.obLength = offsetof( BLOBDATA, dwLength );
    dbBinding.obStatus = offsetof( BLOBDATA, dwStatus );
    dbBinding.pTypeInfo = NULL;
    dbBinding.pObject = &dbObj;
    dbBinding.pBindExt = NULL;
    dbBinding.dwPart = DBPART_VALUE | DBPART_STATUS | DBPART_LENGTH;
    dbBinding.dwMemOwner = DBMEMOWNER_CLIENTOWNED;
    dbBinding.eParamIO = DBPARAMIO_NOTPARAM;
    dbBinding.cbMaxLen = 0;
    dbBinding.dwFlags = 0;
    dbBinding.wType = DBTYPE_IUNKNOWN;
    dbBinding.bPrecision = 0;
    dbBinding.bScale = 0;

    HACCESSOR hAccessor = DB_NULL_HACCESSOR;
    DBBINDSTATUS dbs;
    hResult = pIAccessor->CreateAccessor( DBACCESSOR_ROWDATA, 1, &dbBinding, sizeof( BLOBDATA ), &hAccessor, &dbs );

    EAutoReleasePtr pIRowset;
    hResult = pIRowsetChange->QueryInterface( IID_IRowset, ( void** )&pIRowset );

    ULONG uRowsObtained = 0;
    HROW* phRows = NULL;
    hResult = pIRowset->GetNextRows( NULL, 0, 1, &uRowsObtained, &phRows );

    CSequentialStream* pss = new CSequentialStream;
    pss->PreAllocBuffer( 1024 ); // 預先分配好內存,并讀入數據
    pss->Write( pszSomebuffer, 512, NULL ); // pss->Write可以連續調用
    pss->Write( pszSomebuffer+512, 512, NULL );
    pss->ResetPosition( );

    BLOBDATA bd;
    bd.pISeqStream = ( ISequentialStream* )pss;
    bd.dwStatus = DBSTATUS_S_OK;
    bd.dwLength = pss->GetLength( );

    // 將 BLOB 數據寫入到數據庫
    hResult = pIRowsetChange->SetData( phRows[0], hAccessor, &bd );

    pIAccessor->ReleaseAccessor( hAccessor, NULL );
    pIRowset->ReleaseRows( uRowsObtained, phRows, NULL, NULL, NULL );

    // pss was released by pIRowsetChange->SetData.

    這樣,我們就完成了一條記錄的添加。讀取BLOB字段的代碼跟上面的完全類似,只要把
    hResult = pIRowset->GetNextRows( NULL, 0, 1, &uRowsObtained, &phRows );
    后面的那些改成下面的代碼即可。

    BLOBDATA bd;
    hResult = pIRowset->GetData( phRows[0], hAccessor, &bd );
    if( bd.dwStatus == DBSTATUS_S_ISNULL )
    {
    // 此字段為空
    }
    else if( bd.dwStatus != DBSTATUS_S_OK || bd.pISeqStream == NULL )
    {
    // 失敗
    }
    else
    {
    // 從系統分配的 ISequentialStream 接口讀入 BLOB 數據
    BYTE szReadBuffer[1024];
    for( ULONG uRead = 0U; ; )
    {
    if( FAILED( bd.pISeqStream->Read( szReadBuffer, 1024, &uRead ) ) )
    {
    break;
    }
    //szReadBuffer中就包含了BLOB字段的數據
    if( uRead != 1024 )
    {
    break;
    }
    }
    bd.pISeqStream->Release( );
    }
    pIAccessor->ReleaseAccessor( hAccessor, NULL );
    pIRowset->ReleaseRows( uRowsObtained, phRows, NULL, NULL, NULL );

    總結

    以上是生活随笔為你收集整理的VC++ OLE DB 读写数据库的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    久久精品国产免费观看 | 在线精品观看国产 | 国产美女在线免费观看 | 国产精品久久三 | 91日韩精品一区 | 成年人视频在线观看免费 | 狠狠色丁香婷婷综合久小说久 | 成人a视频在线观看 | 久久久久国产a免费观看rela | 亚洲少妇影院 | 97精品视频在线播放 | 久久精品久久久久 | 色视频在线观看 | 激情欧美在线观看 | 伊人久久影视 | 久久国产免费看 | 欧美日韩久久一区 | 欧美黑人巨大xxxxx | 在线观看的a站 | 在线观看久| 国产精品18久久久久久久久久久久 | www.久久久com | 91最新视频 | www.黄色 | 亚洲精品黄色在线观看 | 色五月激情五月 | 日日操网 | 国产最新福利 | 色噜噜在线观看 | 日本在线观看一区二区三区 | 国产成人精品一区二区 | 日韩欧美高清一区二区三区 | 美女黄频免费 | 2018亚洲男人天堂 | 欧美在一区 | 国产午夜视频在线观看 | 欧美性色综合网站 | 国产精品一区二 | 手机av网站| 亚洲一二三在线 | 中文字幕av网站 | 日本h视频在线观看 | 色中色亚洲 | 欧美大码xxxx| 缴情综合网五月天 | 国产视频1区2区3区 久久夜视频 | 一本色道久久综合亚洲二区三区 | 国产一区在线不卡 | 中文字幕亚洲欧美 | 在线播放91 | 91热精品 | 九九九九九精品 | 欧美日韩不卡在线视频 | 亚洲精品一区二区三区在线观看 | 亚洲蜜桃av | 激情久久伊人 | 国产美女精品人人做人人爽 | 91成年人在线观看 | 精品福利国产 | av片子在线观看 | 久草在线中文888 | 精品视频在线看 | 日韩免费看片 | 久草在线视频首页 | 久久免费国产视频 | 久久综合九色综合久久久精品综合 | www.com黄色 | 在线观看免费一级片 | 波多野结衣综合网 | 欧美日韩视频一区二区三区 | 在线观看国产www | 国产特级毛片aaaaaa毛片 | 国内久久精品视频 | 国产精品久久毛片 | 少妇视频一区 | 亚洲在线高清 | 99精品毛片 | 久草综合在线观看 | 国产美女久久 | 在线v| 日本精品va在线观看 | 久久国语 | av一区二区在线观看中文字幕 | 最新日本中文字幕 | 99久久精品电影 | 欧美在线不卡一区 | 日韩欧美在线综合网 | 2024av在线播放 | 久久99国产一区二区三区 | 91精品视频一区二区三区 | 黄色片免费电影 | 国产不卡精品 | 欧美在线观看小视频 | 免费国产一区二区视频 | 亚洲一级二级三级 | 日韩首页 | 在线免费观看亚洲视频 | 樱空桃av| 日韩在线中文字幕 | 久久久国产一区 | 国产在线视频导航 | 久久精品一区二区三 | 成人黄色小说视频 | av在线a | 日韩免费不卡av | 亚洲九九 | 国产精品久久久久久久99 | 国产精品免费不 | 久久精品在线视频 | 天天色天天艹 | 九九久久免费 | 美女视频黄是免费的 | 国产美女精品视频 | 亚洲日本在线视频观看 | 一区二区三区视频在线 | 色小说av | 91亚色视频 | 国产精品区一区 | 视频在线亚洲 | 亚洲天天综合 | 91精品国自产在线观看 | 日韩在线免费电影 | wwwwwww色| 99久久精品久久久久久动态片 | 国产系列在线观看 | 五月激情婷婷丁香 | 91精品久久久久久久91蜜桃 | 久草精品电影 | 91中文字幕 | 中文字幕一区二区三区四区视频 | 最近最新中文字幕视频 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 九草视频在线观看 | 中文字幕电影网 | 久久免费观看少妇a级毛片 久久久久成人免费 | 五月天综合激情网 | 日韩在线观看高清 | 草久视频在线 | 久草视频首页 | 国产精品日韩在线播放 | 国产精品欧美日韩 | 免费看黄色小说的网站 | 日韩在线电影一区 | 色99在线| 成人av免费播放 | 99精品热视频只有精品10 | av高清免费| 日韩毛片在线一区二区毛片 | 99re久久资源最新地址 | 国产精品久久久久久久久久东京 | 91精品视频免费看 | 最近中文字幕免费av | 日韩理论影院 | 日韩精品中文字幕在线不卡尤物 | 日韩久久一区二区 | 91福利在线观看 | 人人艹视频 | 国产做aⅴ在线视频播放 | 91久久久久久久一区二区 | 久久不卡国产精品一区二区 | 99国内精品久久久久久久 | 在线免费黄色片 | 一级片黄色片网站 | 日日弄天天弄美女bbbb | 在线观看国产日韩 | 欧美激情精品久久久久久免费印度 | www黄色 | 欧美在线视频精品 | 久久免费黄色 | 91原创在线观看 | 日韩视频1区 | 综合色综合色 | 久久草草热国产精品直播 | 东方av免费在线观看 | 久久超碰在线 | 国产精品永久久久久久久www | 亚洲精品国产精品国自产 | 香蕉在线播放 | 成年人黄色免费视频 | 看片黄网站 | 欧美亚洲一级片 | 五月婷丁香网 | 国产精品久久久久久久久大全 | 欧美福利网址 | 亚洲精品久久在线 | 丁香影院在线 | 在线视频久久 | 久久精品电影院 | 国产高清视频网 | 狠狠干狠狠操 | 免费十分钟| 日韩精品一区二区三区在线视频 | 久久综合干 | 国产一区自拍视频 | 久久久精品国产免费观看同学 | 免费看片成年人 | 一区二区三区观看 | 贫乳av女优大全 | 午夜久久福利影院 | 欧美性极品xxxx做受 | 少妇视频在线播放 | 久久黄视频 | 日本中文在线观看 | 美女视频黄是免费的 | 国产拍揄自揄精品视频麻豆 | 久久久午夜精品福利内容 | 亚洲国产欧美在线人成大黄瓜 | 亚洲国产精品传媒在线观看 | 久久综合偷偷噜噜噜色 | 精品91视频 | 中文字幕在线观看第二页 | 亚洲精品在线资源 | 日本在线视频一区二区三区 | 久久精品毛片 | 色哟哟国产精品 | 欧美日本中文字幕 | 日韩二区在线播放 | 色婷婷六月天 | 欧美日韩伦理一区 | 国产一区二区在线免费播放 | 一级性视频 | 日本精品视频在线观看 | 亚洲专区视频在线观看 | 亚洲精品午夜久久久 | 国产国产人免费人成免费视频 | 操高跟美女 | 天天天干天天射天天天操 | 日韩黄色一区 | 亚洲在线日韩 | 欧美精品一区二区免费 | 欧美日韩不卡在线视频 | 国产日韩精品一区二区三区在线 | 成人免费观看在线视频 | 欧美日韩不卡一区二区 | 日日爽天天操 | 午夜10000 | 欧美一级免费片 | 主播av在线| 久久精品国产亚洲aⅴ | www.久久久.cum | 中文字幕在线看视频国产中文版 | 你操综合 | 蜜臀av网站 | 久久久.com| 在线播放视频一区 | 国产精品6| 国产精品国产三级在线专区 | 草久视频在线观看 | a v在线观看 | 99热最新在线 | 国产v在线 | 中文免费在线观看 | 免费色视频网址 | 一区 二区 精品 | 亚洲精品一区二区三区高潮 | 日韩色一区二区三区 | 久久dvd| 亚洲日本va中文字幕 | 三级视频国产 | 九九九热精品免费视频观看网站 | 久久免费黄色网址 | 91av看片| 九九热免费在线视频 | 最近2019中文免费高清视频观看www99 | 91精品日韩 | 中文网丁香综合网 | 成人全视频免费观看在线看 | 成人黄色在线电影 | 久草国产在线观看 | 午夜国产一区二区三区四区 | 亚洲国产无 | 欧美日韩另类视频 | 手机成人在线 | 国产一区二区手机在线观看 | 色激情在线 | 天天综合导航 | 在线观看av小说 | 婷婷精品国产欧美精品亚洲人人爽 | jizzjizzjizz亚洲| 国产精品麻豆一区二区三区 | av电影免费在线播放 | 国产精品国产三级国产aⅴ无密码 | 亚洲国产精品久久久久久 | 一级α片免费看 | 视频国产精品 | 色网免费观看 | 日日干,天天干 | 综合久色| 久久精品免费观看 | 久久精品91久久久久久再现 | 五月天天av | 久草在线视频网站 | 欧美亚洲国产日韩 | 在线观看中文字幕第一页 | 97人人模人人爽人人喊中文字 | 日日夜夜精品网站 | 久久天堂影院 | 国产黄影院色大全免费 | 黄色国产精品 | 国产精品成人一区二区 | 一区二区三区在线电影 | 伊人国产视频 | 999在线观看视频 | 免费三级黄色片 | 香蕉手机在线 | 亚洲免费小视频 | 国内小视频在线观看 | 国产精品综合久久久久 | 2021av在线| 免费a视频在线 | www.成人sex| 丁香婷婷激情国产高清秒播 | 色婷婷综合久久久久中文字幕1 | 丁香花中文在线免费观看 | 亚洲视频在线观看 | 激情视频免费观看 | 久久天天躁夜夜躁狠狠85麻豆 | 亚洲精品在线电影 | 中文字幕在线播放第一页 | 香蕉在线视频观看 | 美国av片在线观看 | 一级片免费观看 | 亚洲最大av在线播放 | 激情大尺度视频 | 一区二区三区在线免费播放 | 久久精品一区二区三 | 亚洲一级黄色 | 国产一卡二卡在线 | 欧美激情一区不卡 | av电影在线免费观看 | 亚洲天堂在线观看完整版 | 午夜视频免费在线观看 | 中文在线8资源库 | 日韩精品一区二区三区免费视频观看 | 精品成人免费 | 国产精品成人一区二区 | 久久国产成人午夜av影院潦草 | 久99久久| 久久精品99精品国产香蕉 | 五月婷婷欧美视频 | 亚洲一区二区黄色 | 国产精品久久久久久久久久久久久 | 亚洲精品在线视频播放 | 国产一区二区三区 在线 | 精品久久1 | 九九影视理伦片 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 国产亚洲资源 | 91mv.cool在线观看 | 国产1区2区3区精品美女 | 亚洲精品国产电影 | 免费观看国产视频 | 一本一本久久a久久 | 九九九九精品九九九九 | 99久久婷婷国产精品综合 | 久久婷婷国产色一区二区三区 | 日韩大片在线看 | 美女网站免费福利视频 | 免费午夜网站 | av成人免费在线看 | 欧美精品免费在线 | 最近的中文字幕大全免费版 | 国产性xxxx| 天天操网 | 中文字幕在线观 | 久久视频这里有久久精品视频11 | 91超级碰| 国产精品日韩久久久久 | 欧美视频网址 | 国产精品久久视频 | 亚洲乱码国产乱码精品天美传媒 | 亚洲h视频在线 | 超级av在线 | 欧美福利在线播放 | 国产麻豆电影 | 91福利影院在线观看 | 六月丁香婷婷久久 | 国产色综合天天综合网 | 2024国产精品视频 | 91av精品 | 香蕉网站在线观看 | 国产一区二区三区视频在线 | 三级性生活视频 | 天天干人人干 | 四虎国产视频 | 91在线免费播放视频 | 精品福利在线观看 | 五月婷婷操 | 波多野结衣亚洲一区二区 | 一二区av| 天天天色综合 | 国产蜜臀av | 91手机电影 | 久久伦理影院 | 成人中文字幕+乱码+中文字幕 | 天天射天天操天天干 | 久久久美女 | 男女视频91 | 久久怡红院 | 亚洲国产影院av久久久久 | 欧美日韩视频 | 天天干,狠狠干 | 国内成人精品视频 | 91麻豆精品国产91久久久无限制版 | 免费看三片 | 人人舔人人 | 中文字幕精品www乱入免费视频 | 日韩三级一区 | 亚洲精品午夜久久久久久久 | 91刺激视频 | 天天操夜夜操天天射 | 中文字幕 91 | 免费在线观看成人小视频 | 色综合天天天天做夜夜夜夜做 | av黄色免费看 | 麻豆一精品传二传媒短视频 | 狠色狠色综合久久 | 亚洲欧美色婷婷 | 波多野结衣一区二区三区中文字幕 | 精品视频一区在线观看 | 国产精品一区二区在线观看免费 | 久久国产片 | 粉嫩av一区二区三区免费 | 日韩亚洲在线视频 | 国产免费观看高清完整版 | 97色在线观看| 国产精品一区在线观看你懂的 | 成 人 黄 色视频免费播放 | 黄色大全视频 | 亚洲人成在线观看 | 久久久久久毛片精品免费不卡 | 黄色片软件网站 | 亚洲国产手机在线 | 一区二区三区免费在线观看 | 精品伦理一区二区三区 | 成人av播放 | av大片免费看 | 久久久久久久18 | 视频 国产区 | 亚洲人av免费网站 | 久青草视频在线观看 | 国产成人综 | 天天综合网入口 | 久久久久久久久久久久久久免费看 | 国产一区二区久久久 | 中文字幕第一 | 手机av在线不卡 | 四虎影视成人 | 国产成人一区二区三区在线观看 | 婷婷亚洲五月 | 香蕉视频国产在线观看 | 黄免费在线观看 | 婷婷在线免费 | 亚洲女人av| 亚洲精品美女久久久 | 亚洲国产精品资源 | 九色福利视频 | 国产玖玖精品视频 | 日韩特黄av | 国产96精品 | 香蕉97视频观看在线观看 | 久久人人做 | 亚洲精品国产精品久久99热 | 91精品在线观看入口 | 中国老女人日b | 奇米先锋 | 久久在草 | 韩国av免费观看 | 成人免费视频播放 | 日韩大陆欧美高清视频区 | 国产一区在线播放 | 高潮毛片无遮挡高清免费 | 激情文学综合丁香 | 欧美激情视频一区 | 午夜国产一区二区三区四区 | 国产精品精品国产色婷婷 | 日韩高清dvd | 特黄特色特刺激视频免费播放 | 国产日韩欧美在线影视 | 国产手机视频精品 | 欧美天堂视频在线 | 国产 视频 久久 | 91精品久久久久久久99蜜桃 | 18+视频网站链接 | 五月婷婷综合在线 | 99综合电影在线视频 | 天天操天天干天天爽 | 激情综合网婷婷 | 亚洲人视频在线 | 亚洲免费在线观看视频 | 丁香高清视频在线看看 | 国产精品久久久久久一区二区 | 久久精品日本啪啪涩涩 | 欧美成人黄色 | 91在线免费视频观看 | 久久久国产成人 | 免费看一级片 | 亚洲专区一二三 | 一区二区三区在线观看免费 | 国产自在线 | 97手机电影网 | 中文字幕中文字幕在线一区 | 97视频人人澡人人爽 | 欧美精品亚洲精品 | 天天操天天操天天爽 | 日韩久久影院 | 亚洲一区二区精品在线 | 免费视频久久久久久久 | 精品国产一区二区三区久久久蜜月 | 伊人影院在线观看 | 亚洲精品456在线播放乱码 | 久久人人爽人人爽人人片av软件 | 操操操日日日干干干 | 久久久国产精品一区二区中文 | 亚洲激情视频在线 | 国产精久久 | 黄色不卡av | 黄av资源 | 一区二区中文字幕在线观看 | 国产专区欧美专区 | 波多野结衣在线中文字幕 | 又黄又网站 | 亚洲黄色在线播放 | 三级黄色在线 | 91电影福利 | 最新日本中文字幕 | 免费看污网站 | 91免费高清在线观看 | 欧美另类一二三四区 | 久要激情网 | 国产精品午夜在线观看 | 91视视频在线直接观看在线看网页在线看 | 亚洲国产精品激情在线观看 | 国产精品久久久久久久久久ktv | 久久 精品一区 | av经典在线| 视频精品一区二区三区 | 国产一区二区手机在线观看 | 91一区二区三区在线观看 | 亚洲婷婷在线视频 | 中文永久字幕 | av网站播放| 激情五月婷婷激情 | 一级特黄aaa大片在线观看 | 亚洲91网站 | 97狠狠干 | 亚洲精品国偷拍自产在线观看蜜桃 | 丁香六月天婷婷 | 免费中午字幕无吗 | 国产精品久久精品 | 男女激情免费网站 | 亚洲久草网 | 免费久久99精品国产婷婷六月 | 国产1区2区3区在线 亚洲自拍偷拍色图 | 极品中文字幕 | 国产精品毛片一区二区三区 | 欧美综合色在线图区 | 99成人在线视频 | 日本高清dvd| 亚洲黄色一级电影 | 啪啪免费视频网站 | 日韩欧美在线第一页 | 国产精品av免费在线观看 | 美女国产| 中文字幕超清在线免费 | 91传媒激情理伦片 | 天天草夜夜 | 免费黄在线看 | 天天综合日 | 亚洲精品高清一区二区三区四区 | 91精品久久久久久综合乱菊 | 成人av免费在线播放 | 麻豆国产网站入口 | 操少妇视频 | 在线观看视频一区二区三区 | 天天弄天天操 | 国产123av| 韩日在线一区 | 久久爽久久爽久久av东京爽 | 五月婷婷六月丁香在线观看 | 亚洲永久字幕 | 亚洲 欧美 另类人妖 | 97在线观看免费高清完整版在线观看 | 麻豆视频www | 成人免费视频网 | 日韩免费视频一区二区 | 日韩午夜电影院 | 91精品网站在线观看 | 操操操人人人 | 欧美a√在线 | 成人国产精品一区二区 | 免费亚洲一区二区 | 最新国产精品亚洲 | 亚洲午夜精品久久久久久久久 | 91精品资源 | 99re亚洲国产精品 | 激情视频免费在线观看 | 超碰免费97| 国产成人中文字幕 | 天天操天天弄 | 91精品爽啪蜜夜国产在线播放 | 四虎永久网站 | 日韩欧美在线观看一区二区三区 | 欧美日韩精品在线免费观看 | 精品在线观看一区二区 | 天天综合网在线观看 | 国产综合片 | 国产婷婷 | 天天干天天干天天干 | 日韩一区正在播放 | 亚洲激情在线观看 | 日韩偷拍精品 | 精品一区二区三区久久 | 日韩区欠美精品av视频 | av大片免费 | 最近中文字幕高清字幕在线视频 | 四虎影视国产精品免费久久 | av网站在线免费观看 | 久草在线视频新 | 国产小视频91 | 欧美性色黄大片在线观看 | 三级黄色a| 一区二区三区精品在线视频 | 欧美精品中文在线免费观看 | 超碰人人在线观看 | 国产一级做a爱片久久毛片a | 日日摸日日添夜夜爽97 | av专区在线 | 久久久久亚洲精品男人的天堂 | 色婷婷亚洲婷婷 | 亚洲成人av在线电影 | 91片黄在线观看 | 欧美日韩国语 | 日本黄色片一区二区 | 在线观看黄色小视频 | 中文字幕一区二区三区视频 | 久香蕉| 波多野结衣精品视频 | 国产高清av免费在线观看 | 最新中文字幕在线观看视频 | 91亚洲精品久久久蜜桃 | 麻豆va一区二区三区久久浪 | 天天操网址 | 波多野结衣在线观看一区二区三区 | 国产综合91| 精品久久久久久一区二区里番 | 天天干天天搞天天射 | 999久久精品 | 久久99久久99精品免观看粉嫩 | 久久久免费精品视频 | 国产一级片免费视频 | 青草草在线 | 伊人中文网| 手机看片| 亚洲三级毛片 | 亚洲精品视频在线观看网站 | 超碰av在线播放 | 日韩欧美一区二区三区在线 | 国产xxxx性hd极品 | 黄色亚洲大片免费在线观看 | 在线免费观看黄 | 97超碰成人 | 国产一区二区精品在线 | 亚洲2019精品 | 久久影视精品 | 高清av网站 | 亚洲成人黄色在线观看 | 婷婷伊人网 | 国产欧美综合在线观看 | 国产成人精品不卡 | 久久久在线观看 | 精品你懂的 | 国产一二区免费视频 | 夜色成人网 | 亚洲精品国偷拍自产在线观看蜜桃 | 免费观看9x视频网站在线观看 | 就要色综合 | 中文在线免费视频 | 伊人影院得得 | 黄色软件视频大全免费下载 | 久久精品国产久精国产 | 中文字幕一区二区三区四区 | 91久久精品日日躁夜夜躁国产 | 五月天婷亚洲天综合网精品偷 | 中文字幕刺激在线 | www.夜夜操.com | 日韩偷拍精品 | 精品久久久久久一区二区里番 | 日本精品xxxx | 超碰免费久久 | 99 久久久久 | 69欧美视频| 一区二区三区电影在线播 | 久久久久观看 | 久久久久久久久影视 | 伊人久久五月天 | 美女黄视频免费看 | 在线观看www. | 操操操av | 一区二区视频在线看 | 一区二区三区视频在线 | 麻豆传媒视频在线免费观看 | 99精品视频免费在线观看 | 色婷婷骚婷婷 | 亚洲天堂va | 日韩av电影手机在线观看 | 中文字幕91在线 | 国产精品成人免费精品自在线观看 | 最新午夜电影 | 国产精品热 | 91粉色视频 | 色播五月婷婷 | 2024av在线播放| 色婷婷狠狠五月综合天色拍 | 日韩理论片 | 人人讲 | 韩国av免费看 | 国产精品国产三级国产 | 国产精品欧美 | 国产黄色看片 | 天天爽天天摸 | 黄污在线观看 | 毛片网站免费 | 人人超碰免费 | 午夜黄色大片 | www夜夜| 免费在线成人av | 中文字幕亚洲欧美日韩2019 | 美女国产免费 | 国产日韩一区在线 | www.久久com| 992tv成人免费看片 | 狠狠操91| 久久99国产精品自在自在app | 亚洲精品在线观看视频 | 中文字幕一区二区三区在线观看 | 久久成人资源 | 国产一级免费播放 | 久久久久国产精品厨房 | 超碰在线个人 | 四虎影视www | 美女搞黄国产视频网站 | 免费在线观看国产精品 | www色,com | 欧美日韩国产成人 | 国内久久久久 | 欧美成人区 | 中文字幕人成人 | 狠狠的干狠狠的操 | 精品久久网 | 亚洲精品乱码久久久久久蜜桃91 | 99精品视频在线播放观看 | 久草视频观看 | 久久精品视频网址 | 国产中文字幕第一页 | h视频日本 | 国产精品嫩草影院123 | 91| 国内精品一区二区 | 午夜三级影院 | 久久久久久影视 | 免费成人av | 欧美性性网 | 免费观看国产成人 | 国产免费亚洲 | 国产精品久久久av久久久 | 国产96精品| 日本久久综合视频 | 欧美一区在线看 | 欧美一级专区免费大片 | 午夜视频在线观看一区二区三区 | 激情片av| 午夜视频99 | 91亚洲影院 | 天天操夜夜操国产精品 | 国产成人区| 国产精品一二 | 免费在线色| 国产成人精品一区二区在线观看 | 欧美一区二区三区在线视频观看 | 精品无人国产偷自产在线 | 国产精品9999 | 黄色大片入口 | 操操操综合 | 欧美成人手机版 | 国产综合精品久久 | 亚洲免费黄色 | 国产精品k频道 | 五月天.com | 日本激情视频中文字幕 | 久久午夜精品影院一区 | 国产精品久久久久久高潮 | 91精品国自产拍天天拍 | 亚洲精品高清视频在线观看 | 97在线观看视频免费 | 久久xx视频 | 日韩艹| 天天天天天天干 | 亚洲欧美婷婷六月色综合 | 美女视频免费一区二区 | 夜夜夜| 天天干,天天操,天天射 | 欧美黑人性猛交 | 亚洲欧美一区二区三区孕妇写真 | 91精品国产乱码久久 | 在线观看成人小视频 | 日本xxxx.com | 免费色视频在线 | 国产精品igao视频网入口 | 另类五月激情 | 欧美在一区 | 成人网在线免费视频 | 久久综合色影院 | 欧美一区二区三区在线视频观看 | 97色资源| 欧美激情视频一区二区三区 | 五月婷婷av在线 | 亚洲精品一区中文字幕乱码 | 久草在线电影网 | 热久在线 | 日韩大片免费观看 | 日本亚洲国产 | 国产999视频在线观看 | 免费av在线网站 | 国产成人av片 | 久久精品一区二区三区国产主播 | 天天综合网在线 | 香蕉网在线观看 | 精品国产乱码久久久久久浪潮 | 99国产高清 | 欧美成人免费在线 | 久久久久久高潮国产精品视 | 一区二区毛片 | 粉嫩高清一区二区三区 | 青草草在线视频 | 欧美-第1页-屁屁影院 | 日韩在线观看第一页 | 精品亚洲男同gayvideo网站 | 免费观看黄 | 嫩模bbw搡bbbb搡bbbb | 国产精品久久久久永久免费 | 99精品福利视频 | 一本一道久久a久久精品 | 免费观看的av | 看片一区二区三区 | 日韩h在线观看 | 亚洲国产日韩av | 91色吧| www.狠狠插.com | 91免费视频网站在线观看 | 国产午夜精品一区二区三区嫩草 | 久久国语 | 亚洲一区天堂 | 亚洲综合小说 | 国产女人免费看a级丨片 | 国产一区二区中文字幕 | 波多野结衣视频一区二区三区 | 色播99| 亚洲精品永久免费视频 | 五月天激情综合 | 亚洲精品视频在线观看网站 | 91在线看黄 | 国产亚洲人成网站在线观看 | 六月丁香社区 | 久久兔费看a级 | 久草香蕉在线视频 | 婷婷精品国产欧美精品亚洲人人爽 | 国产精品婷婷午夜在线观看 | 玖玖玖影院 | 五月天堂网| 中文字幕高清免费日韩视频在线 | 国产99久久久国产精品 | 色搞搞 | 国产最新视频在线 | 免费看的视频 | 中文字幕在线看片 | 高清久久久久久 | 欧美一级片免费观看 | 91传媒在线看 | 久久免费视频网站 | 欧美日韩在线观看一区二区 | 99在线精品免费视频九九视 | 免费日韩一区二区三区 | 久久久久久久久久久网 | 中文字幕欲求不满 | 欧美一区二区三区在线播放 | 成人一级免费视频 | 国产亚洲精品久久网站 | 91av官网 | 中文字幕久久亚洲 | 久久伦理电影网 | 成人亚洲精品国产www | 色综合天天色综合 | 亚洲 中文 欧美 日韩vr 在线 | 亚洲电影一级黄 | 日韩精品免费在线视频 | 99久久日韩精品视频免费在线观看 | 久久视频在线视频 | 日韩电影久久久 | 久久综合九色99 | 综合久久久久久久久 | 看污网站| 国产亚洲精品久久久久久无几年桃 | 日日夜夜精品视频天天综合网 | 91视频在线免费 | 国产成人精品免费在线观看 | 久久久在线视频 | 97网在线观看 | 日韩大片在线播放 | 亚洲精品高清在线观看 | 国产在线观看一区 | 日韩精品在线观看视频 | 在线免费视频你懂的 | 激情欧美国产 | 99免费在线播放99久久免费 | a在线免费 | 欧美三级在线播放 | 国产精品欧美久久久久无广告 | 久久久在线免费观看 | 91在线色| 国产在线精品一区二区三区 | 片网站| 啪一啪在线 | 国产一区二区三精品久久久无广告 | 美女黄久久 | 久久久黄色av | 日韩午夜精品福利 | 国产精品久久久久久久午夜片 | 91精品系列 | 国产不卡免费视频 | 日韩欧美高清视频在线观看 | 亚洲在线资源 | 欧美国产一区二区 | 国产精品9999久久久久仙踪林 | 911香蕉 | 激情久久久久久久久久久久久久久久 | 91视频一8mav | 久久精品精品电影网 | 2023国产精品自产拍在线观看 | 精品91久久久久 | av成人动漫在线观看 | 在线国产一区二区 | 国产精品6999成人免费视频 | 色天堂在线视频 | 国产成人av网址 | 黄免费在线观看 | 四虎8848免费高清在线观看 | 一区二区视频欧美 | 一区二区三区观看 | 超碰人人在 | 亚洲黄在线观看 | av青草 | 一级黄色片在线免费观看 | 五月天堂网 | 天堂在线一区二区三区 | 激情综合婷婷 | 亚洲成人免费在线观看 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 日韩av片在线 | 久久av福利| www.狠狠插.com | 97色婷婷成人综合在线观看 | 综合av在线 | 99久久日韩精品视频免费在线观看 | 很黄很污的视频网站 | av综合站| 狠狠久久综合 | 久久久国产一区二区三区四区小说 | 国产精品成人国产乱一区 | 韩国一区在线 | 日本中文字幕电影在线免费观看 | 亚洲精选在线 | 久久久久一区二区三区 | 国产精品伦一区二区三区视频 | 五月色婷| 九色自拍视频 | 97人人射| 成人av午夜 | 国产a级精品| 久久国内精品视频 | 日韩欧美一级二级 | 91在线观看视频网站 | 一区二区三区日韩视频在线观看 | 日韩av中文字幕在线 | 亚洲一区二区三区毛片 | 人人看黄色| 精品国产片 | 中文字幕欧美激情 | 免费在线观看av电影 | 99精品久久久久久久 | 欧美性另类| www.99热精品| 99久久精品国产一区二区成人 | 青草草在线视频 | 亚洲人在线7777777精品 | 国产精品区一区 | 亚洲欧美日韩国产 | 日韩成人免费在线 |