久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

DNN 数据访问策略 (转)

發布時間:2023/11/27 生活经验 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 DNN 数据访问策略 (转) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?

經過幾天斷斷續續的努力,這篇文章終于翻譯結束,文章主要講了DNN的數據訪問策略,對于了解系統整體上是如何工作的有一定的幫助,希望能給dnn的初學者一些有用的信息。由于翻譯的匆忙+水平有限,錯誤或不當之處在所難免,歡迎大家討論、指正。

原作者:

Shaun Walker – Perpetual Motion Interactive Systems Inc.

http://www.perpetualmotion.ca

?

?

目錄

?

?

簡介... 2

策略... 2

需求... 3

配置... 4

數據訪問層 ( DAL ). 8

數據庫腳本... 11

數據庫對象命名... 12

應用程序塊... 12

數據傳輸... 12

業務邏輯層 ( BLL ). 13

自定義業務對象助手 ( CBO ). 14

空處理機制... 16

實現細節... 19

緩存... 25

性能... 26

開發... 26

自定義模塊... 27

改進核心模塊... 29

sql命令發生器... 30

參考... 30

?

?

?

?

?

?

?

簡介

?

DotNetNuke(以下簡稱DNN)的最終目的是創建一個門戶的框架平臺,這個平臺可以為開發者增添模塊搭建應用程序提供堅實的可靠的支持。應用程序的一個關鍵的功能就是數據存取。.NET Framework提供了多種數據存取的方法,從架構的角度來看從這么多方法中選出適合自己的需求的最佳的解決方案很難。本白皮書將嘗試著在DNN應用程序的實現中提供最合適的數據存取策略。

策略

?

?

在很多資料中有各種關于.NET Framework數據存取方法的介紹,然而他們大多脫離了現實的實際應用。雖然大家常常討論的是這些方法的優點和缺點,但是現在仍有很多開發者不知道如何選擇自己的最佳策略。事實上每種方法都有適合它的不同的用例,理論上這是對的,這也是難以選擇的原因,然而在實踐中,每一個開發者都在尋找一個適合所有企業應用的存取策略。

一致的數據存取策略有許多好處,有了統一定義好的數據存取策略,開發者就無需浪費時間來為每個任務選擇數據存取方法,這種模式提高了代碼的維護性,在所有的應用程序范圍內實現了一致性。通過數據存取組件的集中處理使得數據存取策略風險降低了,也使得代碼的完整性增強了。

一致的兼容的數據存取策略的概念的確跟每個需求應用其最佳的數據存取策略相悖。為每個應用程序選擇相應的最佳的數據存取策略能夠獲得最好的性能(假定你能夠從所有的用例中篩選出最適合的方案)。可是這樣可能導致團隊在開發實踐中難以協調的合作。

DotNetNuke拋棄了眾所周知的傳統的80/20原則,它把精力集中在提供一致的兼容的數據存取策略,這個策略理想的目標是把80%的精力放在應用程序用例上,剩下的20%用來考慮跟用其他的數據存取方法相比是否性能要求是必須的,同時也采用了上面所述的策略。

?

?

?

?

需求

?

DNN的一個重要的需求就是要提供一個能夠支持多種數據存儲應用程序的實現方法。

????? 由于對外部數據存儲通信的靈活性和性能的要求,我們選擇放棄一般的數據存取方法而打造一個新的應用,這個新的應用主要利用了數據庫本地化特征集(也就是用.NET管理提供者、所有的SQL語言、存儲過程等等)。在選擇特殊的數據庫訪問類時我們做了權衡,我們需要為我們想要支持的每個數據庫平臺寫一個特殊的數據訪問層,因此應用程序也就包含了更多的代碼。數據訪問層共享了大量共同的代碼,每一個訪問層都明確的處理了特殊數據庫應用。

????? 為了簡便的應用數據庫訪問類我們選擇了提供者模式(也就是GOF描述的工廠設計模式),這種模式是通過反射的在應用程序運行時動態的加載正確的(適合的)數據訪問對象。工廠是這樣實現的:先創建一個抽象類,這個類聲明了一個方法,這個方法是每一個數據訪問類都必須繼承實現的。對每一個我們支持的數據庫,我們創建了一個具體的實現類,這個類實現了抽象類或“協議”中定義的各種數據庫操作的代碼。為了支持在運行時動態加載具體的操作類,我們在工廠里實現了一個Instance()方法,這個方法依賴于提供者類從配置文件讀取并反射過來的值來決定需要加載哪個程序集。由于反射在應用程序性能方面非常耗費資源,我們把數據庫提供者類的構造器儲存到緩存里。

????? ?那么為什么用抽象類而不用接口呢?這是因為接口是(不可變的)靜態的,而且因此接口也不能將其自身復制(翻譯)。由于接口不支持實現方法繼續繼承,所以這些類的模式不采用接口。為接口增加一個方法跟為基類增加一個抽象方式是等效的;任何類實現了接口它也就終止了,因為這些類不能再實現新的方法(確切的說應該是接口定義以外的方法接口無法使用)。

????? 下面的圖表展示了業務邏輯、工廠以及數據庫存取類是如何相互聯系的。這個解決方案的關鍵優勢是只要數據訪問類實現了DataProvider抽象類的方法,數據庫訪問類就能夠在業務邏輯類之后編譯。這就意味著在我們想要創建另一個數據庫的實現方法時我們無需改變業務邏輯層(或用戶界面層),創建另一個實現方法的步驟是:

1、? 為新的數據庫創建數據庫訪問類,這些類實現了DataProvider的抽象類。

2、? 將這些類類編譯成一個程序集。

3、? 測試并配置這個新的數據訪問程序集到正在運行的服務器。

4、? 修改配置文件,來指定新的數據庫訪問類。

5、? 無需對業務邏輯組件進行任何改變也無需重新編譯它。

?

?

?

?

?

配置

?

?????? Web.config文件包含了許多配置節來使DataProvider模式起作用。第一個配置節注冊了這些提供者(Providers)和他們相應的配置節處理方法(ConfigurationSectionHandlers)。盡管在這個例子中我們僅僅展示了DotNetNuke配置節組中的一個,我們可以通過類似的方法配置其它的提供者(也就是抽象驗證提供者等等)。但有一點是必須保證的,那就是web.config文件中必須實現這些配置節。

?

??? <configSections>

??????? <sectionGroup name="dotnetnuke">

??????????? <section name="data" type="DotNetNuke.ProviderConfigurationHandler, DotNetNuke" />

??????? </sectionGroup>

??? </configSections>

?

下面的配置節是為老式的數據訪問方法的模塊而保留的:

??? <appSettings>

??????? <add key="connectionString" value="Server=localhost;Database=DotNetNuke;uid=sa;pwd=;" />

??? </appSettings>

?

如上最終實現了大量的提供者模塊。<dotnetnuke>配置組中的<data>配置節名稱需要有一個默認的提供者(defaultProvider)屬性,這個屬性依賴于下面的<providers>集合中的特定的實例。在從一個provider轉變為另一個provider的時候defaultProvider被用來作為單一的轉換器。如果沒有指定默認的provider,這個配置集合中的第一項就被認為是默認的。

?????? <data>配置節也包含了一個<providers>集合說明,確定了所有的<data>實現都是唯一的。每一個provider都必須至少包含name、type和providerPath屬性(name不是特定的但是通常相應的類名,type指定了provider相關的強類名,providerPath指定了provider的特殊資源例如腳本在哪里)。每一個提供者同樣可以有多個自定義屬性。

?

?

??? <dotnetnuke>

??????? <data defaultProvider="SqlDataProvider" >

??????????? <providers>

??????? ? <clear/>

??????????????? <add name = "SqlDataProvider"

??????????????????????? type = "DotNetNuke.Data.SqlDataProvider, DotNetNuke.SqlDataProvider"

??????????????????????? connectionString = "Server=localhost;Database=DotNetNuke;uid=sa;pwd=;"

??? ??????????????????? providerPath = "~\database\SqlDataProvider\"

??????????????????????? objectQualifier = "DotNetNuke"

??????????????????????? databaseOwner = "dbo"

??????????????? />

??????????????? <add name = "AccessDataProvider"

??????????????????????? type = "DotNetNuke.Data.AccessDataProvider, DotNetNuke.AccessDataProvider"

??????????????????????? connectionString = "PROVIDER=Microsoft.Jet.OLEDB.4.0;"

??? ??????????????????? providerPath = "~\database\AccessDataProvider\"

??????????????????????? objectQualifier = "DotNetNuke"

??????????????????????? databaseFilename = "DotNetNuke.mdb"

??????????????? />

??????????? </providers>

??????? </data>

??? </dotnetnuke>

?

下面是對providers集合中的節點作用的詳細說明。

<providers>配置節包含了一個或多個<add>、<remove>、<clear>元素。下面的規則應用在處理這些元素的時候:

?

?

1、? 聲明一個空的<providers />不是錯誤。

2、? Providers繼承了父配置中<add>聲明的項。

3、? 如果某項已經存在了或被繼承了再用<add>重新定義那么這是錯誤的。

4、? <remove>一個不存在的項是錯誤的。

5、? 如果一個項被<add>后又被<remove>了,然后再<add>這個完全相同的項是可以的(不是錯誤)。

6、? 如果一個項<add>, <clear>,然后再<add>是可以的(不是錯誤的)。

7、? <clear>會清除所有在先前定義的和繼承的項。例如:先用<add>聲明再用<clear>清除那么項就不存在了,而在<clear>后再<add>聲明的項是不會被清除的。

?

<add>

描述

增加一個數據提供者(data provider)。

屬性

Name——provider的友好的名稱。

Type——一個實現了provider接口的類。這個值是一個程序集的完整的關聯。

providerPath——查找provider的特殊資源(如腳本)的路徑。

其它name/value對——也許還有一些附加的名稱/值對,所有的名稱/值對都是provider能夠理解的(處理的)。

?

<remove>

描述

清除一個指定的數據提供者

屬性

Name——要清除的provider的友好名稱。

?

?

<clear>

描述

清除所有的繼承的提供者。

?

\Components\Provider.vb

?

Provider.vb類提供了所有的實現細節,這些實現包括從web.config文件加載provider的信息以及應用<add>, <remove>, <clear>處理的規則(標準)。這是一個通用的(generic)類,它不僅僅適用于數據訪問。

?

\Components\DataProvider.vb

?

DataProvider.vb是一個抽象類,這個類包含了DNN的所有的數據訪問方法。它包含了一個工廠本身的實例方法(Instance()),它負責在運行時動態加載web.config中描述的合適的程序集。

?

??????? ' unique provider name used for caching

??????? Private Const ProviderType As String = "data"

??????? Private Const ProviderName As String = ""

?

??????? Public Shared Function Instance() As DataProvider

?

??????????? ' Use the cache because the reflection used later is expensive

??????????? Dim cache As System.Web.Caching.Cache = System.Web.HttpContext.Current.Cache

?

??????????? If cache(ProviderName & ProviderType & "provider") Is Nothing Then

?

??????????????? ' Get the name of the provider

??????????????? Dim objProviderConfiguration As ProviderConfiguration = ProviderConfiguration.GetProviderConfiguration(ProviderType)

?

??????????????? ' The assembly should be in \bin or GAC, so we simply need to get an instance of the type

??????????????? Try

?

??????????????????? ' Get the typename of the DataProvider ( ie. DotNetNuke.Data.SqlDataProvider, DotNetNuke.SqlDataProvider )

??????????????????? Dim strTypeName As String = CType(objProviderConfiguration.Providers(objProviderConfiguration.DefaultProvider), Provider).Type

??????????????????? ' Override the typename if a ProviderName is specified ( this allows the application to load a different DataProvider assembly for custom modules )

??????????????????? strTypeName.Replace(objProviderConfiguration.DefaultProvider, ProviderName & objProviderConfiguration.DefaultProvider)

??? ????????????????' Use reflection to store the constructor of the class that implements DataProvider

??????????????????? Dim t As Type = Type.GetType(strTypeName, True)

?

??????????????????? ' Insert the type into the cache

??????????????????? cache.Insert(ProviderName & ProviderType & "provider", t.GetConstructor(System.Type.EmptyTypes))

?

??????????????? Catch e As Exception

?

??????????????? End Try

??????????? End If

?

??????????? Return CType(CType(cache(ProviderName & ProviderType & "provider"), ConstructorInfo).Invoke(Nothing), DataProvider)

?

??????? End Function

?

?

?????? 所有的數據訪問方法都被定義成必須重寫的(MustOverride)。也就是說所有的從詞類派生的數據提供者類都必須提供這些方法的實現。這些定義了業務邏輯層和數據存取層之間聯系的抽象類協議。

?

??????? ' links module

??????? Public MustOverride Function GetLinks(ByVal ModuleId As Integer) As IDataReader

??????? Public MustOverride Function GetLink(ByVal ItemID As Integer, ByVal ModuleId As Integer) As IDataReader

??????? Public MustOverride Sub DeleteLink(ByVal ItemID As Integer)

??????? Public MustOverride Sub AddLink(ByVal ModuleId As Integer, ByVal UserName As String, ByVal Title As String, ByVal Url As String, ByVal MobileUrl As String, ByVal ViewOrder As String, ByVal Description As String, ByVal NewWindow As Boolean)

??????? Public MustOverride Sub UpdateLink(ByVal ItemId As Integer, ByVal UserName As String, ByVal Title As String, ByVal Url As String, ByVal MobileUrl As String, ByVal ViewOrder As String, ByVal Description As String, ByVal NewWindow As Boolean)

數據訪問層( DAL )

?

數據訪問層(DAL)必須實現數據提供者抽象類中聲明的方法。然而,每一個DAL提供者在實現這些方法時也許很不相同。這種處理允許提供者靈活的選擇他們自己的數據庫訪問協議(也就是說:.NET管理的OleDB, ODBC等)。同樣也允許提供者處理數據庫平臺之間的所有不同之處(例如:存儲過程,sql語言語法,@@IDENTITY)。

每一個數據提供者必須為其在web.config中的自定義屬性指定一個實現方法。

Imports System

Imports System.Data

Imports System.Data.SqlClient

Imports Microsoft.ApplicationBlocks.Data

Imports System.IO

Imports System.Web

Imports DotNetNuke

?

Namespace DotNetNuke.Data

?

??? Public Class SqlDataProvider

?

??????? Inherits DataProvider

?

??????? Private Const ProviderType As String = "data"

?

??????? Private _providerConfiguration As ProviderConfiguration = ProviderConfiguration.GetProviderConfiguration(ProviderType)

??????? Private _connectionString As String

??????? Private _providerPath As String

??????? Private _objectQualifier As String

??????? Private _databaseOwner As String

?

??????? Public Sub New()

?

??????????? ' Read the configuration specific information for this provider

??????????? Dim objProvider As Provider = CType(_providerConfiguration.Providers(_providerConfiguration.DefaultProvider), Provider)

?

??????????? ' Read the attributes for this provider

??????????? _connectionString = objProvider.Attributes("connectionString")

?

??????????? _providerPath = objProvider.Attributes("providerPath")

?

??????????? _objectQualifier = objProvider.Attributes("objectQualifier")

??????????? If _objectQualifier <> "" And _objectQualifier.EndsWith("_") = False Then

??????? ????????_objectQualifier += "_"

??????????? End If

?

??????????? _databaseOwner = objProvider.Attributes("databaseOwner")

??????????? If _databaseOwner <> "" And _databaseOwner.EndsWith(".") = False Then

??????????????? _databaseOwner += "."

??????????? End If

?

??????? End Sub

?

??????? Public ReadOnly Property ConnectionString() As String

??????????? Get

??????????????? Return _connectionString

??????????? End Get

??????? End Property

?

??????? Public ReadOnly Property ProviderPath() As String

??????????? Get

??????????????? Return _providerPath

??????????? End Get

??????? End Property

?

??????? Public ReadOnly Property ObjectQualifier() As String

??????????? Get

??????????????? Return _objectQualifier

??????????? End Get

??????? End Property

?

??????? Public ReadOnly Property DatabaseOwner() As String

??????????? Get

??????????????? Return _databaseOwner

??????????? End Get

??????? End Property

?

數據訪問方法必須涉及成簡單的查詢(例如 單一的select,insert,update,delete),以便于在所有的數據庫平臺上他們都能被實現。業務邏輯(例如條件分支,計算或局部變量)應該在業務邏輯層實現,這樣才能從數據庫抽象出來并集中到一個應用程序(模塊)里處理。如果你經常用那些使你可以在數據庫層實現程序邏輯的富sql語言變量工作的話,這種數據庫訪問是相當簡單的。

DNN中的Sql server/msde 數據提供者用了存儲過程作為最好的數據訪問技術。

?

??????? ' links module

??????? Public Overrides Function GetLinks(ByVal ModuleId As Integer) As IDataReader

??????????? Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "GetLinks", ModuleId), IDataReader)

??????? End Function

??????? Public Overrides Function GetLink(ByVal ItemId As Integer, ByVal ModuleId As Integer) As IDataReader

??????????? Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "GetLink", ItemId, ModuleId), IDataReader)

??????? End Function

??????? Public Overrides Sub DeleteLink(ByVal ItemId As Integer)

??????????? SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DeleteLink", ItemId)

??????? End Sub

??????? Public Overrides Sub AddLink(ByVal ModuleId As Integer, ByVal UserName As String, ByVal Title As String, ByVal Url As String, ByVal MobileUrl As String, ByVal ViewOrder As String, ByVal Description As String, ByVal NewWindow As Boolean)

??????????? SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "AddLink", ModuleId, UserName, Title, Url, MobileUrl, IIf(ViewOrder <> "", ViewOrder, DBNull.Value), Description, NewWindow)

??????? End Sub

??????? Public Overrides Sub UpdateLink(ByVal ItemId As Integer, ByVal UserName As String, ByVal Title As String, ByVal Url As String, ByVal MobileUrl As String, ByVal ViewOrder As String, ByVal Description As String, ByVal NewWindow As Boolean)

??????????? SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "UpdateLink", ItemId, UserName, Title, Url, MobileUrl, IIf(ViewOrder <> "", ViewOrder, DBNull.Value), Description, NewWindow)

??????? End Sub

?

?????? DNN用到存儲過程(存儲過程查詢)但是沒有用參數自動查找的特性( CommandBuilder.DeriveParameters ),因此參數必須明確的定義。

?

??????? ' links module

??????? Public Overrides Function GetLinks(ByVal ModuleId As Integer) As IDataReader

??????????? Return CType(OleDBHelper.ExecuteReader(ConnectionString, CommandType.StoredProcedure, ObjectQualifier & "GetLinks", _

??????????????? New OleDbParameter("@ModuleId", ModuleId)), IDataReader)

??????? End Function

??????? Public Overrides Function GetLink(ByVal ItemId As Integer, ByVal ModuleId As Integer) As IDataReader

??????????? Return CType(OleDBHelper.ExecuteReader(ConnectionString, CommandType.StoredProcedure, ObjectQualifier & "GetLink", _

??????????????? New OleDbParameter("@ItemId", ItemId), _

??????????????? New OleDbParameter("@ModuleId", ModuleId)), IDataReader)

??????? End Function

??????? Public Overrides Sub DeleteLink(ByVal ItemId As Integer)

??????????? OleDBHelper.ExecuteNonQuery(ConnectionString, CommandType.StoredProcedure, ObjectQualifier & "DeleteLink", _

??????????????? New OleDbParameter("@ItemId", ItemId))

??????? End Sub

??????? Public Overrides Sub AddLink(ByVal ModuleId As Integer, ByVal UserName As String, ByVal Title As String, ByVal Url As String, ByVal MobileUrl As String, ByVal ViewOrder As String, ByVal Description As String, ByVal NewWindow As Boolean)

??????????? OleDBHelper.ExecuteNonQuery(ConnectionString, CommandType.StoredProcedure, ObjectQualifier & "AddLink", _

??????????????? New OleDbParameter("@ModuleId", ModuleId), _

??????????????? New OleDbParameter("@UserName", UserName), _

??????????????? New OleDbParameter("@Title", Title), _

??????????????? New OleDbParameter("@Url", Url), _

???????????? ???New OleDbParameter("@MobileUrl", MobileUrl), _

??????????????? New OleDbParameter("@ViewOrder", IIf(ViewOrder <> "", ViewOrder, DBNull.Value)), _

??????????????? New OleDbParameter("@Description", Description), _

??????????????? New OleDbParameter("@NewWindow", NewWindow))

??????? End Sub

??????? Public Overrides Sub UpdateLink(ByVal ItemId As Integer, ByVal UserName As String, ByVal Title As String, ByVal Url As String, ByVal MobileUrl As String, ByVal ViewOrder As String, ByVal Description As String, ByVal NewWindow As Boolean)

??????????? OleDBHelper.ExecuteNonQuery(ConnectionString, CommandType.StoredProcedure, ObjectQualifier & "UpdateLink", _

??????????????? New OleDbParameter("@ItemId", ItemId), _

??????????????? New OleDbParameter("@UserName", UserName), _

??????????????? New OleDbParameter("@Title", Title), _

??????????????? New OleDbParameter("@Url", Url), _

??????????????? New OleDbParameter("@MobileUrl", MobileUrl), _

??????????????? New OleDbParameter("@ViewOrder", IIf(ViewOrder <> "", ViewOrder, DBNull.Value)), _

??????????????? New OleDbParameter("@Description", Description), _

??????????????? New OleDbParameter("@NewWindow", NewWindow))

??????? End Sub

?

數據庫腳本

?

?????? DNN包含了一個自動升級的特性,也就是當有了一個新的應用程序版本發布后,應用程序能夠自動更新數據庫。不過腳本必須根據版本號和數據提供者命名(例如02.00.00.SqlDataProvider),并且必須放在web.config文件中providerPath屬性所指定的目錄下。動態升級的實現需要腳本中重寫provider所實現的ExecuteScript的方法。這對安全規范和對象命名很有用。

create procedure {databaseOwner}{objectQualifier}GetLinks

?

@ModuleId int

?

as

?

select ItemId,

?????? CreatedByUser,

?????? CreatedDate,

??? ???Title,

?????? Url,

?????? ViewOrder,

?????? Description,

?????? NewWindow

from {objectQualifier}Links

where? ModuleId = @ModuleId

order by ViewOrder, Title

?

GO

?

數據庫對象命名??

?????? web.config文件包含了一個名字叫objectQualifer的屬性,它允許你為數據庫對象指定一個前綴(例如DNN_)。Web主機往往只提供一個數據庫服務器,因此必須跟其它web應用程序共享一個賬號。如果你沒有指定前綴也許會跟已經存在的其它應用程序的數據庫對象名稱沖突。指定前綴的另一個好處就是這些數據庫對象在SQL Server企業管理器等管理工具里當按字母排序的時候他們會分組顯示,這就方便了管理。

?????? 如果你升級的是DotNetNuke2.0以前版本的數據庫,你需要設置objectQualifier為“”。這是因為你也許用了第三方模塊,而這些模塊不用新的DAL體系架構而是用特定的對象名稱。升級設置objectQualifier時會將你所有的核心的數據庫對象重命名,這可能會使你的自定義的模塊出錯。

?

應用程序塊

?

?????? 微軟數據訪問應用程序塊(MSDAAB)是一個.NET組件,它包含了最優化的數據訪問代碼,它能幫助你依靠SQL Server數據庫調用存儲過程、發布sql文本命令。我們借用這些方法作為dnn的一個建造模塊,來減少創建、測試和維護大量自定義的數據訪問方法的代碼。我們也為基于MSDAAB代碼的微軟Access數據提供者創建了一個OleDB.ApplicationBlocks.Data程序集。

?????? 比起在我們的DAL實現方法里包含真正的資源代碼來說,我們選擇用MSDAAB作為一個黑箱組件的實現方法能夠幫助我們防止修改MSDAAB代碼,能夠使我們完美的升級組件,這個新特征是可以實現的。

?

數據傳輸

?????? DotNetNuke用DataReader把從數據訪問層(DAL)那里讀取的數據集合傳遞給業務邏輯層(BLL)。選用DataReader是因為它是ADO.NET提供的租塊的數據傳輸機制(一個只向前的只讀的數據流)。IDataReader是所有.NET兼容的數據讀取器(DataReaders)的基本接口。這個抽象的IDataReader接口使我們能夠在各層之間傳輸數據,而無需考慮數據訪問協議在實際的數據提供者實現中可不可用(例如SqlClient, OleDB, ODBC等)。

?

業務邏輯層 ( BLL )

?????? 好的面向對象設計推薦我們將數據存儲從應用程序中提取(抽象)出來。通過提取可以在應用程序上建立一個獨立的業務邏輯接口集;因此減少了對下面的數據庫物理實現的依賴。

?????? DNN的業務邏輯層被有效的定義在\Components的子文件夾下。業務邏輯層包含了表述層調用的各種應用程序服務的抽象類。在數據訪問方面,業務邏輯層向前調用應用程序接口(API)到適當的數據提供者,這個過程就文檔前面介紹的數據提供者工廠機制。

?????? 自定義業務對象是一個用自定義的數據結構封裝數據的面向對象的技術。自定義業務對象需要一些自定義的代碼,這就在類型安全設計模型、分離數據存儲和序列化方面增加了開銷。自定義業務對象提供了最大程度的靈活性,他們使應用程序可以在它的抽象范圍內定義自己的數據結構;也消除了對所有數據容器的依賴(例如RecordSet, DataSet )。

?????? 什么是類型安全的設計模型呢?考慮一下下面的數據訪問代碼例子:變量= DataReader(“字段名”)。這里將數據庫字段的值賦給了一個變量,這段代碼的問題在于無法保證數據庫字段的數據類型和變量的數據類型相匹配;并且這個過程中的任何錯誤都將提交給運行時(run-time)來處理。采用自定義業務對象那么代碼將是這樣:變量=對象.屬性(variable = Object.Property)。這樣的話編譯器就會在數據不匹配的時候迅速的告知我們。類型安全的設計還可以智能感知和改進代碼的易讀性。

?????? 一組對象我們成為一個集合。在DNN里我們用了標準的動態數組(ArrayList)來描述一組自定義業務對象。ArrayLists是ASP.NET內部對象,它包含了基本集合所需要的所有特征(add,remove,find,iterate)。在ArrayList的特征里我們最重要的特征是它實現了IEnumerable接口,它可以被數據綁定(databound)給ASP.NET web控件(web control)。

?????? DNN的數據訪問層是以DataReader的形式傳遞信息給業務邏輯層的。關于這種實現的一個問題就是為什么DNN用DataReader作為數據傳輸容器(container)來傳輸數據而不直接從DAL層傳遞數據給自定義業務對象。這是因為雖然這兩種方法都是可行的,但我們相信使DAL層從BLL層完全獨立出來是由一些優點的。例如:我們要為自定義業務對象增加一個附加屬性,這種情況下這個屬性僅僅是表述層用到而數據庫中根本不需要,用DNN的方法,DAL層實現方法不需要做任何改動,因為他們對上面的BLL層沒有任何依賴;但是如果DAL直接提供數據給自定義業務對象,所有的DAL層實現都需要重新編譯來符合BLL層結構的需要。

?

?

?

?

自定義業務對象助手 ( CBO )

?????? 為了最小化移植從數據層傳輸來到自定義業務邏輯對象信息的代碼工作量,創建了一個通用的utility類。這個類包含了兩個公共的方法(函數)——一個是返回一個單獨對象的實例,一個是返回一個集合對象(arraylist)。一般來說這個類里定義的每個屬性在Datareader里都有相應的字段對應。這些影射的信息的名稱和數據類型都必須是唯一的。下面的代碼展示了如何用反射將datareader里的數據填充給自定義業務對象然后再關閉datareader。

?

?

??? Public Class CBO

?

??????? Private Shared Function GetPropertyInfo(ByVal objType As Type) As ArrayList

?

??????????? ' Use the cache because the reflection used later is expensive

??????????? Dim objCache As System.Web.Caching.Cache = System.Web.HttpContext.Current.Cache

?

??????????? If objCache(objType.Name) Is Nothing Then

??????????????? Dim objProperties As New ArrayList()

??????????????? Dim objProperty As PropertyInfo

??????????????? For Each objProperty In objType.GetProperties()

??????????????????? objProperties.Add(objProperty)

??????????????? Next

??????????????? objCache.Insert(objType.Name, objProperties)

??????????? End If

?

??????????? Return CType(objCache(objType.Name), ArrayList)

?

??????? End Function

?

??????? Private Shared Function GetOrdinals(ByVal objProperties As ArrayList, ByVal dr As IDataReader) As Integer()

?

????????? ??Dim arrOrdinals(objProperties.Count) As Integer

??????????? Dim intProperty As Integer

?

??????????? If Not dr Is Nothing Then

??????????????? For intProperty = 0 To objProperties.Count - 1

??????????????????? arrOrdinals(intProperty) = -1

?????????????? ?????If CType(objProperties(intProperty), PropertyInfo).CanWrite Then

??????????????????????? Try

??????????????????????????? arrOrdinals(intProperty) = dr.GetOrdinal(objProperties(intProperty).Name)

??????????????????????? Catch

????????????????????????? ??' property does not exist in datareader

??????????????????????? End Try

??????????????????? End If

??????????????? Next intProperty

??????????? End If

?

??????????? Return arrOrdinals

?

??????? End Function

?

??????? Private Shared Function CreateObject(ByVal objType As Type, ByVal dr As IDataReader, ByVal objProperties As ArrayList, ByVal arrOrdinals As Integer()) As Object

?

??????????? Dim objObject As Object = Activator.CreateInstance(objType)

??????????? Dim intProperty As Integer

?

??????????? ' fill object with values from datareader

??????????? For intProperty = 0 To objProperties.Count - 1

??????????????? If arrOrdinals(intProperty) <> -1 Then

??????????????????? If IsDBNull(dr.GetValue(arrOrdinals(intProperty))) Then

??????????????????????? ' translate Null value

??????????????????????? objProperties(intProperty).SetValue(objObject, Null.SetNull(CType(objProperties(intProperty), PropertyInfo)), Nothing)

??????????????????? Else

??????????????????????? Try

??????????????????????????? ' try implicit conversion first

??????????????????????????? objProperties(intProperty).SetValue(objObject, dr.GetValue(arrOrdinals(intProperty)), Nothing)

??????????????????????? Catch ' data types do not match

??????????????????????????? Try

??????????????????????????????? ' try explicit conversion

??????????????????????????????? objProperties(intProperty).SetValue(objObject, Convert.ChangeType(dr.GetValue(arrOrdinals(intProperty)), CType(objProperties(intProperty), PropertyInfo).PropertyType), Nothing)

???????????????????? ???????Catch

??????????????????????????????? ' error assigning a datareader value to a property

??????????????????????????? End Try

??????????????????????? End Try

??????????????????? End If

??????????????? End If

??????????? Next intProperty

?

??????????? Return objObject

?

??????? End Function

?

??????? Public Shared Function FillObject(ByVal dr As IDataReader, ByVal objType As Type) As Object

?

??????????? Dim objFillObject As Object

??????????? Dim intProperty As Integer

?

??????????? ' get properties for type

??????????? Dim objProperties As ArrayList = GetPropertyInfo(objType)

?

??????????? ' get ordinal positions in datareader

??????????? Dim arrOrdinals As Integer() = GetOrdinals(objProperties, dr)

?

??????????? ' read datareader

??????????? If dr.Read Then

??????????????? ' fill business object

??????????????? objFillObject = CreateObject(objType, dr, objProperties, arrOrdinals)

??????????? Else

??????????????? objFillObject = Nothing

??????????? End If

?

??????????? ' close datareader

??????????? If Not dr Is Nothing Then

??????????????? dr.Close()

??????????? End If

?

??????????? Return objFillObject

?

??????? End Function

?

??????? Public Shared Function FillCollection(ByVal dr As IDataReader, ByVal objType As Type) As ArrayList

?

??????????? Dim objFillCollection As New ArrayList()

??????????? Dim objFillObject As Object

??????????? Dim intProperty As Integer

?

??????????? ' get properties for type

??????????? Dim objProperties As ArrayList = GetPropertyInfo(objType)

?

??????????? ' get ordinal positions in datareader

??????????? Dim arrOrdinals As Integer() = GetOrdinals(objProperties, dr)

?

??????????? ' iterate datareader

??????????? While dr.Read

??????????????? ' fill business object

??????????????? objFillObject = CreateObject(objType, dr, objProperties, arrOrdinals)

??????????????? ' add to collection

??????????????? objFillCollection.Add(objFillObject)

??????????? End While

?

??????????? ' close datareader

??????????? If Not dr Is Nothing Then

??????????????? dr.Close()

??????????? End If

?

??????????? Return objFillCollection

?

??????? End Function

?

??? End Class

空處理

?

?????? 每一個數據存取系統都有一個特殊的構造來處理那些沒有明確指定的字段值。

在大多數關系數據庫管理系統中,這個構造就是眾所周知的null值。從應用程序的角度看,在表述層和數據存取層傳遞null值是一個架構上的挑戰。這是因為表述層必須從數據庫的特定信息抽象出來;而且,當一個屬性值沒有明確指定的時候表述層也必須能夠表達說明。事實上這相當復雜,.NET Framework的本身的數據類型不能自動的轉換從數據庫返回的null值(如果你試圖直接那樣賦值的話將會拋出一個異常)。另外,每一個數據存儲都有它自己的屬性來實現null。唯一合理的解決方案就是創建一個抽象的傳輸服務,來編碼/解碼應用程序各層之間的null值。

?

?????? 乍一看,你也許會想到用vb.net中的“nothing”關鍵字可以很好的擔負起這個傳輸服務的任務。不幸的是,調查顯示,.NET Framework本身的數據類型處理“nothing”的時候沒有預想的那么好。盡管分配為nothing的屬性不會拋出異常,實際上這個屬性的值將非常依賴于它的數據類型(String = Nothing, Date = Date.MinValue, Integer = 0, Boolean = False, 等等)并且自帶的IsNothing()函數的結果還不是一致的(兼容的)結果。

?

?????? 在DNN里,我們創建了一個通用的類來處理null的問題,它統一管理應用程序各層的null問題。在應用程序中用一個常量來描述每種數據類型的null情況,再把這個常量轉化成各種數據存儲實現里的實際的null值。這個類包含的各種方法將null轉換服務的物理細節從應用程序中抽象出來了。

?????? * 記住,這個類僅僅用在數據庫字段允許有null值的情況下。還要記住,這個類要求DAL和BLL層之間的數據類型一致(例如:一個BLL信息類里的屬性字段的數據類型必須跟DAL 數據提供者傳遞過來的參數的數據類型一致)。

?

?

??? Public Class Null

?

??????? ' define application encoded null values

??????? Public Shared ReadOnly Property NullInteger() As Integer

??????????? Get

??????????????? Return -1

??????????? End Get

??? ????End Property

??????? Public Shared ReadOnly Property NullDate() As Date

??????????? Get

??????????????? Return Date.MinValue

??????????? End Get

??????? End Property

??????? Public Shared ReadOnly Property NullString() As String

??????????? Get

?????? ?????????Return ""

??????????? End Get

??????? End Property

??????? Public Shared ReadOnly Property NullBoolean() As Boolean

??????????? Get

??????????????? Return False

??????????? End Get

??????? End Property

?

??????? ' sets a field to an application encoded null value ( used in Presentation layer )

??????? Public Shared Function SetNull(ByVal objField As Object) As Object

??????????? If TypeOf objField Is Integer Then

??????????????? SetNull = NullInteger

??????????? ElseIf TypeOf objField Is Date Then

??????????????? SetNull = NullDate

??????????? ElseIf TypeOf objField Is String Then

??????????????? SetNull = NullString

??????????? ElseIf TypeOf objField Is Boolean Then

??????????????? SetNull = NullBoolean

??????????? Else

??????????????? Throw New NullReferenceException()

??????????? End If

??????? End Function

?

??????? ' sets a field to an application encoded null value ( used in BLL layer )

??????? Public Shared Function SetNull(ByVal objPropertyInfo As PropertyInfo) As Object

??????????? Select Case objPropertyInfo.PropertyType.ToString

??????????????? Case "System.Int16", "System.Int32", "System.Int64", "System.Single", "System.Double", "System.Decimal"

??????????????????? SetNull = NullInteger

??????????????? Case "System.DateTime"

??????????????? ????SetNull = NullDate

??????????????? Case "System.String", "System.Char"

??????????????????? SetNull = NullString

??????????????? Case "System.Boolean"

??????????????????? SetNull = NullBoolean

??????????????? Case Else

??????????????????? Throw New NullReferenceException()

??????????? End Select

??????? End Function

?

??????? ' convert an application encoded null value to a database null value ( used in DAL )

??????? Public Shared Function GetNull(ByVal objField As Object, ByVal objDBNull As Object) As Object

??????????? GetNull = objField

??????????? If TypeOf objField Is Integer Then

??????????????? If objField = NullInteger Then

??????????????????? GetNull = objDBNull

??????????????? End If

??????????? ElseIf TypeOf objField Is Date Then

?????????????? ?If objField = NullDate Then

??????????????????? GetNull = objDBNull

??????????????? End If

??????????? ElseIf TypeOf objField Is String Then

??????????????? If objField = NullString Then

??????????????????? GetNull = objDBNull

??????????????? End If

???? ???????ElseIf TypeOf objField Is Boolean Then

??????????????? If objField = NullBoolean Then

??????????????????? GetNull = objDBNull

??????????????? End If

??????????? Else

??????????????? Throw New NullReferenceException()

??????????? End If

??????? End Function

?

??????? ' checks if a field contains an application encoded null value

??????? Public Shared Function IsNull(ByVal objField As Object) As Boolean

??????????? If objField = SetNull(objField) Then

??????????????? IsNull = True

??????????? Else

???? ???????????IsNull = False

??????????? End If

??????? End Function

?

??? End Class

實現細節

?????? 下面的一段代碼例子示范了應用程序的各層之間是如何完成數據訪問的。

?

表述層( UI )

?????? 表述層依賴于它上面的業務邏輯層。自定義業務邏輯對象的屬性和方法建立了這兩個曾之間的基礎接口(表述層不要直接調用數據訪問層的方法)。

?

?

獲取

?

?????? ' create a Controller object

??? Dim objAnnouncements As New AnnouncementsController

?

??? ' get the collection

??? lstAnnouncements.DataSource = objAnnouncements.GetAnnouncements(ModuleId)

??? lstAnnouncements.DataBind()

?

增加/更新

?

??? ...

??? Private itemId As Integer

???

??? If Not (Request.Params("ItemId") Is Nothing) Then

??????? itemId = Int32.Parse(Request.Params("ItemId"))

??? Else

??????? itemId = Null.SetNull(itemId)

??? End If

??? ...

?

??? ' create an Info object

??? Dim objAnnouncement As New AnnouncementInfo

?

??? ' set the properties

??? objAnnouncement.ItemId = itemId

??? objAnnouncement.ModuleId = ModuleId

??? objAnnouncement.CreatedByUser = Context.User.Identity.Name

??? objAnnouncement.Title = txtTitle.Text

??? objAnnouncement.Description = txtDescription.Text

??? objAnnouncement.Url = txtExternal.Text

??? objAnnouncement.Syndicate = chkSyndicate.Checked

??? If txtViewOrder.Text <> "" Then

??????? objAnnouncement.ViewOrder = txtViewOrder.Text

??? Else

??????? objAnnouncement.ViewOrder = Null.SetNull(objAnnouncement.ViewOrder)

??? End If

??? If txtExpires.Text <> "" Then

??????? objAnnouncement.ExpireDate = txtExpires.Text

??? Else

??????? objAnnouncement.ExpireDate = Null.SetNull(objAnnouncement.ExpireDate)

??? End If

?

??? ' create a Controller object

??? Dim objAnnouncements As New AnnouncementsController

?

??? If Null.IsNull(itemId) Then

??????? ' add

??????? objAnnouncements.AddAnnouncement(objAnnouncement)

??? Else

??????? ' update

??????? objAnnouncements.UpdateAnnouncement(objAnnouncement)

??? End If

?

??? ** Notice the use of the Null.SetNull() and Null.IsNull() helper methods

?

刪除

?

?????? ' create a Controller object

??? Dim objAnnouncements As New AnnouncementsController

?

??? ' delete the record

??? objAnnouncements.DeleteAnnouncement(itemId)

?

業務邏輯層( BLL )

?

?????? 每一個應用程序業務方法都有跟它相對應的多關系業務對象組成的物理文件。每一個業務對象定義都有一個定義它的屬性的信息類和定義它的方法的控制類。

?

??? Public Class AnnouncementInfo

?

??????? ' local property declarations

??????? Private _ItemId As Integer

??????? Private _ModuleId As Integer

??????? Private _UserName As String

??????? Private _Title As String

??????? Private _Url As String

??????? Private _Syndicate As Boolean

??????? Private _ExpireDate As Date

??????? Private _Description As String

??????? Private _ViewOrder As Integer

??????? Private _CreatedByUser As String

??????? Private _CreatedDate As Date

??????? Private _Clicks As Integer

?

? ??????' constructor

??????? Public Sub New()

??????? ' custom initialization logic

??????? End Sub

?

??????? ' public properties

??????? Public Property ItemId() As Integer

??????????? Get

??????????????? Return _ItemId

??????????? End Get

??????????? Set(ByVal Value As Integer)

??????????????? _ItemId = Value

??????????? End Set

??????? End Property

?

??????? Public Property ModuleId() As Integer

??????????? Get

??????????????? Return _ModuleId

??????????? End Get

??????????? Set(ByVal Value As Integer)

???????? ???????_ModuleId = Value

??????????? End Set

??????? End Property

?

??????? Public Property Title() As String

??????????? Get

??????????????? Return _Title

??????????? End Get

??????????? Set(ByVal Value As String)

??????????????? _Title = Value

?????????? ?End Set

??????? End Property

?

??????? Public Property Url() As String

??????????? Get

??????????????? Return _Url

??????????? End Get

??????????? Set(ByVal Value As String)

??????????????? _Url = Value

??????????? End Set

??????? End Property

?

??????? Public Property Syndicate() As Boolean

??????????? Get

??????????????? Return _Syndicate

??????????? End Get

??????????? Set(ByVal Value As Boolean)

??????????????? _Syndicate = Value

??????????? End Set

??????? End Property

?

??????? Public Property ViewOrder() As Integer

??????????? Get

??????????????? Return _ViewOrder

??????????? End Get

??????????? Set(ByVal Value As Integer)

??????????????? _ViewOrder = Value

??????????? End Set

??????? End Property

?

??????? Public Property Description() As String

?????? ?????Get

??????????????? Return _Description

??????????? End Get

??????????? Set(ByVal Value As String)

??????????????? _Description = Value

??????????? End Set

??????? End Property

?

??????? Public Property ExpireDate() As Date

??????????? Get

??????????? ????Return _ExpireDate

??????????? End Get

??????????? Set(ByVal Value As Date)

??????????????? _ExpireDate = Value

??????????? End Set

??????? End Property

?

??????? Public Property CreatedByUser() As String

??????????? Get

??????????????? Return _CreatedByUser

??????????? End Get

??????????? Set(ByVal Value As String)

??????????????? _CreatedByUser = Value

??????????? End Set

??????? End Property

?

??????? Public Property CreatedDate() As Date

??????????? Get

??????????????? Return _CreatedDate

??????????? End Get

??????????? Set(ByVal Value As Date)

??????????????? _CreatedDate = Value

??????????? End Set

??????? End Property

?

??????? Public Property Clicks() As Integer

??????????? Get

??????????????? Return _Clicks

??????????? End Get

??????????? Set(ByVal Value As Integer)

??????????????? _Clicks = Value

??????????? End Set

??????? End Property

??? End Class

?

每一個數據庫的字段在信息類里都有相對應的屬性。為了使通用的自定義業務對象助手(CBO Helper)類能自動的把從IDataReader接口獲取的數據轉換成自定義的業務對象,數據庫字段和與它直接關聯的屬性在名稱和數據類型方面都必須是唯一的。

?

?

??? Public Class AnnouncementsController

?

??????? Public Function GetAnnouncements(ByVal ModuleId As Integer) As ArrayList

?

??????????? Return CBO.FillCollection(DataProvider.Instance().GetAnnouncements(ModuleId), GetType(AnnouncementInfo))

?

??????? End Function

?

?

??????? Public Function GetAnnouncement(ByVal ItemId As Integer, ByVal ModuleId As Integer) As AnnouncementInfo

?

??????????? Return CType(CBO.FillObject(DataProvider.Instance().GetAnnouncement(ItemId, ModuleId), GetType(AnnouncementInfo)), AnnouncementInfo)

?

??????? End Function

?

?

??????? Public Sub DeleteAnnouncement(ByVal ItemID As Integer)

?

??????????? DataProvider.Instance().DeleteAnnouncement(ItemID)

?

??????? End Sub

?

??????? Public Sub AddAnnouncement(ByVal objAnnouncement As AnnouncementInfo)

?

?

??????????? DataProvider.Instance().AddAnnouncement(objAnnouncement.ModuleId, objAnnouncement.CreatedByUser, objAnnouncement.Title, objAnnouncement.Url, objAnnouncement.Syndicate, objAnnouncement.ExpireDate, objAnnouncement.Description, objAnnouncement.ViewOrder)

?

??????? End Sub

?

??????? Public Sub UpdateAnnouncement(ByVal objAnnouncement As AnnouncementInfo)

?

??????????? DataProvider.Instance().UpdateAnnouncement(objAnnouncement.ItemId, objAnnouncement.CreatedByUser, objAnnouncement.Title, objAnnouncement.Url, objAnnouncement.Syndicate, objAnnouncement.ExpireDate, objAnnouncement.Description, objAnnouncement.ViewOrder)

?

??????? End Sub

?

??? End Class

?

???? 你可能注意到了傳遞信息到數據庫的控制方法(例如:增加和更新)是傳遞一個自定義業務對象實例作為一個參數的。這樣做的優點是:對象定義從BLL層獨立出來,這樣就減少了類定義改變后相應的修改。個別的對象屬性被提取出來作為數量值傳遞給數據訪問層(這是因為DAL不關心BLL對象的結構)。

?

?

數據訪問層 ( DAL )

?

?????? 采用本文上述介紹的提供者技術DNN可以支持多種數據存儲。實際上它包含一個基類,這個基類在運行時決定哪個具體的數據訪問類適合當前的數據訪問請求。

?

?

DataProvider ( 基類 )

?

?? ?' announcements module

??? Public MustOverride Function GetAnnouncements(ByVal ModuleId As Integer) As IDataReader

??? Public MustOverride Function GetAnnouncement(ByVal ItemId As Integer, ByVal ModuleId As Integer) As IDataReader

??? Public MustOverride Sub DeleteAnnouncement(ByVal ItemID As Integer)

??? Public MustOverride Sub AddAnnouncement(ByVal ModuleId As Integer, ByVal UserName As String, ByVal Title As String, ByVal URL As String, ByVal Syndicate As Boolean, ByVal ExpireDate As Date, ByVal Description As String, ByVal ViewOrder As Integer)

??? Public MustOverride Sub UpdateAnnouncement(ByVal ItemId As Integer, ByVal UserName As String, ByVal Title As String, ByVal URL As String, ByVal Syndicate As Boolean, ByVal ExpireDate As Date, ByVal Description As String, ByVal ViewOrder As Integer)

?

SqlDataProvider (具體實現類)

?

在具體類中包含了下面的幫助方法,這個方法用來獨立數據庫null的實現(這個例子中DBNull.Value 是針對SQL Server而言的)并且提供一個簡單的接口。

?

?

??? ' general

??? Private Function GetNull(ByVal Field As Object) As Object

??????? Return Null.GetNull(Field, DBNull.Value)

??? End Function

?

每一個在基類里表明必須繼承的方法在具體類里都必須實現。注意上面的add/update方法里描述的GetNull()函數的使用。

?

??? ' announcements module

??? Public Overrides Function GetAnnouncements(ByVal ModuleId As Integer) As IDataReader

??????? Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "GetAnnouncements", ModuleId), IDataReader)

??? End Function

??? Public Overrides Function GetAnnouncement(ByVal ItemId As Integer, ByVal ModuleId As Integer) As IDataReader

??????? Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "GetAnnouncement", ItemId, ModuleId), IDataReader)

??? End Function

??? Public Overrides Sub DeleteAnnouncement(ByVal ItemId As Integer)

??????? SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DeleteAnnouncement", ItemId)

??? End Sub

??? Public Overrides Sub AddAnnouncement(ByVal ModuleId As Integer, ByVal UserName As String, ByVal Title As String, ByVal URL As String, ByVal Syndicate As Boolean, ByVal ExpireDate As Date, ByVal Description As String, ByVal ViewOrder As Integer)

??????? SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "AddAnnouncement", ModuleId, UserName, Title, URL, Syndicate, GetNull(ExpireDate), Description, GetNull(ViewOrder))

??? End Sub

??? Public Overrides Sub UpdateAnnouncement(ByVal ItemId As Integer, ByVal UserName As String, ByVal Title As String, ByVal URL As String, ByVal Syndicate As Boolean, ByVal ExpireDate As Date, ByVal Description As String, ByVal ViewOrder As Integer)

??????? SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "UpdateAnnouncement", ItemId, UserName, Title, URL, Syndicate, GetNull(ExpireDate), Description, GetNull(ViewOrder))

??? End Sub

緩存

?

?????? 很多數據訪問頻繁的方法采用了web緩存技術通過減少后臺數據庫請求次數的方法來提高性能。System.Web.Caching.Cache命名空間提供一些往緩存中增加內容或從緩存中重新獲取內容的工具。它包含一個字典接口,憑借一個字符串關鍵字來查找對應的對象。這個對象將持續在應用程序的整個生命周期。當應用程序重起后這個緩存才被重新創建。注意,只有序列化的對象才能被加入到緩存里。

?

?

??????????? Dim objCache As System.Web.Caching.Cache = System.Web.HttpContext.Current.Cache

?

??????????? If objCache("GetHostSettings") Is Nothing Then

??????????????? objCache.Insert("GetHostSettings", GetHostSettings())

??????????? End If

??????????? Me.HostSettings = objCache("GetHostSettings")

?

System.Web.Caching.Cache對象還支持緩存管理的一些特征。為防止緩存因為大量的內容項而臃腫不堪,DNN采用一個動態調整的方法來刪除那些超過60秒沒有被訪問的對象。這個特征主要用在有緩存設置的地方。

?

?

??????????? If objCache("GetPortalTabModules" & intTabId.ToString) Is Nothing Then

??????????????? dr = DataProvider.Instance().GetPortalTabModules(Me.PortalId, Me.ActiveTab.TabId)

??????????????? objCache.Insert("GetPortalTabModules" & intTabId.ToString, ConvertDataReaderToDataSet(dr), Nothing, DateTime.MaxValue, TimeSpan.FromSeconds(60))

??????????? End If

?

??????????? ds = objCache("GetPortalTabModules" & intTabId.ToString)

?

當應用程序的操作會影響緩存內容時,每一個受影響的緩存內容項都會被刪除,這樣新的內容項才能加進來。

?

?

??????????? If Not objCache("GetHostSettings") Is Nothing Then

??????????????? objCache.Remove("GetHostSettings")

??????????? End If

?

性能

?????? 為了評測系統的性能我們用了微軟應用程序評測中心(Microsoft Application Center Test)工具,這個工具可以模擬大量的用戶打開很多服務器連接并且快速的提交http請求。為了對比,我們分析了DotNetNuke1.0.10( 采用SqlCommandGenerator )跟DotNetNuke 2.0 ( 采用新的抽象DAL )。下面是測試結果(特別感謝Kenny Rice提供測試援助)。

?

?

DotNetNuke 2.0 ( DAL enhancement )

?

Total number of requests: ??????????????????????????? 93,254

Total number of connections: ?????????????????????? 93,253

?

Average requests per second: ??????????????????????????? 310.85

Average time to first byte (msecs): ???????????????????? 2.37

Average time to last byte (msecs): ???????????????????? 2.46

Average time to last byte per iteration (msecs): 29.58

?

Number of unique requests made in test: ?????????? 12

Number of unique response codes: ??????????????????? 1

?

DotNetNuke 1.0.10 ( SqlCommandGenerator )

?

Total number of requests:????????????????????? 42,350

Total number of connections:??????????????????????? 42,350

?????????????

Average requests per second:????????????????????? 141.17

Average time to first byte (msecs):??????????????? 6.02

Average time to last byte (msecs):??????????????? 6.15

Average time to last byte per iteration (msecs):? 116.94

?????????????

Number of unique requests made in test:??????????? 17

Number of unique response codes:?????????????? 2

開發

?????? DNN提供了靈活的門戶軟件架構。這個應用程序核心提供了大量的服務作為通用的方法,例如會員,角色安全,個性化,管理,站點log,導航和數據存取(訪問)。它還提供了靈活的擴展應用程序增加特殊業務功能的能力。大多數情況下建議將特殊的業務功能從框架核心抽象出來并用自定義模塊實現。這保持了核心的完成性并且為將來升級提供了最好的選擇。但是,如果你絕對必須修改核心實體的話,你也不會受到你的需求變化的限制。

?

自定義模塊

?????? DNN允許將自定義模塊打包成私有的程序集發布到門戶安裝。只要較小的修改,自定義模塊在數據存取方面可以采用相同的技術作為核心。這種方式的另一個優點是能夠為每一個支持的數據庫平臺提供自定義模塊的不同版本。

?????? 在你采用下面論述的數據訪問技術之前,你需要先考慮一下你的組件實際上是否需要支持多種數據庫。DNN不強制你采用提供者模式創建自定義模塊。事實上,如果你清楚你的組件僅僅用在單一的數據庫平臺,那么不需要增加額外的開發努力。開發者作這些決定(判斷)是一種基本的職責(原則)。

?

?

\PrivateAssemblies\Survey

?????? 概觀自定義模塊,它的架構其實跟DNN核心的架構是同樣的方法。它包含了一個叫做SurveyDB.vb的業務邏輯層的類,這個類包含了業務邏輯層的方法。它還包含了它自己的SurveyDataProvider.vb的類(文件名/類名很重要,因為你不想它跟DNN里的DataProvider類沖突)。這種情況下ProviderName常量被設置成上述的類名+ DataProvider字符串值的形式。這對于工廠方法里使用通過相同的配置集中得到的基于相同的數據庫的數據提供者很重要(例如:SurveySqlDataProvider 將會跟SqlDataProvider 使用相同的web.config配置集)。

?

?

Imports System

Imports System.Web.Caching

Imports System.Reflection

?

Namespace DotNetNuke

?

??? Public MustInherit Class SurveyDataProvider

?

??????? ' unique provider name used for caching

??????? Private Const ProviderType As String = "data"

??????? Private Const ProviderName As String = "Survey"

?

而且象DNN里的DataProvider類一樣,它包含了必須的數據存取方法。

?

?????? ?Public MustOverride Function GetSurveys(ByVal ModuleId As Integer) As IDataReader

??????? Public MustOverride Function GetSurvey(ByVal SurveyID As Integer, ByVal ModuleId As Integer) As IDataReader

??????? Public MustOverride Sub AddSurvey(ByVal ModuleId As Integer, ByVal Question As String, ByVal ViewOrder As String, ByVal OptionType As String, ByVal UserName As String)

??????? Public MustOverride Sub UpdateSurvey(ByVal SurveyId As Integer, ByVal Question As String, ByVal ViewOrder As String, ByVal OptionType As String, ByVal UserName As String)

??????? Public MustOverride Sub DeleteSurvey(ByVal SurveyID As Integer)

??????? Public MustOverride Function GetSurveyOptions(ByVal SurveyId As Integer) As IDataReader

??????? Public MustOverride Sub AddSurveyOption(ByVal SurveyId As Integer, ByVal OptionName As String, ByVal ViewOrder As String)

??????? Public MustOverride Sub UpdateSurveyOption(ByVal SurveyOptionId As Integer, ByVal OptionName As String, ByVal ViewOrder As String)

??????? Public MustOverride Sub DeleteSurveyOption(ByVal SurveyOptionID As Integer)

??????? Public MustOverride Sub AddSurveyResult(ByVal SurveyOptionId As Integer)

?

\database

?

?????? 自定義模塊包含數據提供者的實現,我們必須再一次在web.config文件里指定一個自定義屬性定義的實現。

?

Imports System

Imports System.Data

Imports System.Data.SqlClient

Imports Microsoft.ApplicationBlocks.Data

?

Namespace DotNetNuke.Data

?

??? Public Class SurveySqlDataProvider

?

??????? Inherits SurveyDataProvider

?

??????? Private Const ProviderType As String = "data"

?

??????? Private _providerConfiguration As ProviderConfiguration = ProviderConfiguration.GetProviderConfiguration(ProviderType)

??????? Private _connectionString As String

??????? Private _providerPath As String

??????? Private _objectQualifier As String

??????? Private _databaseOwner As String

?

Survey.dnn ( deployment )

?

?????? 為了發布私有的自定義模塊,DNN用到了一個清單文件。增加多個提供者的時候這個文件的結構有些微的變化。

?

?

<module>

? <folder>DesktopModules/Survey</folder>

? <friendlyname>Survey</friendlyname>

? <desktopsrc>Survey.ascx</desktopsrc>

? <mobilesrc></mobilesrc>

? <editsrc>EditSurvey.ascx</editsrc>

? <description>Survey allows you to create custom surveys to obtain public feedback</description>

? <editmoduleicon>icon_survey_32px.gif</editmoduleicon>?

? <uninstall></uninstall>?

? <files>

??? <file>

????? <name>Survey.ascx</name>

??? </file>

??? <file>

????? <name>EditSurvey.ascx</name>

??? </file>

??? <file>

????? <name>Survey.dll</name>

??? </file>

??? <file>

????? <name>DotNetNuke.SurveySqlDataProvider.dll</name>

??? </file>

??? <file>

????? <name>Survey01.00.00.SqlDataProvider</name>

??? </file>

??? <file>

????? <name>Survey Uninstall.SqlDataProvider</name>

??? </file>

??? <file>

????? <name>DotNetNuke.SurveyAccessDataProvider.dll</name>

??? </file>

??? <file>

????? <name>Survey01.00.00.AccessDataProvider</name>

??? </file>

??? <file>

?? ???<name>Survey Uninstall.AccessDataProvider</name>

??? </file>

? </files>

</module>

?

改進核心模塊

?????? 自定義模塊是為門戶架構增加附加功能的首選方法。當然,有時候修改核心功能來滿足你特定的需求也是必需的。為了能修改核心模塊的數據訪問方法,你必須對控制管理提供者模型的面向對象原則有最基本的了解。

?????? 理論上,這個提供者模型采用一個基類派生出實例化的子類的工廠設計模式。事實上,DataProvider類就起這個基類的作用,它定義了所有應用程序的核心數據存取方法。所有的方法被定義成公共的必須繼承的,也就是說它們在基類中只是實簡單的定義而且都沒有實現。

?????? DataProvider類起到一個契約的作用,這個契約要求它的子類都必須完全實現,否則對象的實例化將會失敗。這個意思也就是說如果一個基類要求必須被繼承的方法的參數列表或返回值被修改,那么所有子類的實現也都必須作相應的修改,否則它們不會被正確的上載。不能正確的上載不僅意味著某個特殊方法的調用會失敗,實際上,子類的正確實例化也將徹底失敗。這個契約機制雖然給應用程序帶來一定的弱點,但是它保證了每個子類實現有了最小的標準。

?

?????? 下面的例子示范了有關擴展核心的步驟,假定我們增加一個新的字段到核心表中:

?

1、? 如果需要,修改表述層來顯示和修改新的字段。

2、? 修改相關聯的業務邏輯層的類,在相關方法中添加這個字段(例如AddTable, UpdateTable)。

3、? 修改DataProvider基類因步驟2中變化而帶來的必須的變化,并重新編譯應用程序。

4、? 為每一個DataProvider的子類實現(例如:SqlDataProvider,AccessDataProvider)做必要的修改,重新編譯會顯示基類跟其實現類之間的差異。需要修改的實現類的數量依賴于你的應用支持的不同數據庫的數量。

5、用特殊的數據庫更新命令(如:ALTER TABLE)修改每一個DataProvider子類實現的腳本。如果數據庫提供者用了存儲過程,那么同樣必須寫新版本的存儲過程(用相關的DROP 和CREATE 命令)。

?

SQL命令發生器(SqlCommandGenerator

?????? 早期版本的DNN包含一個叫做SqlCommandGenerator的類,這個類能夠簡單的調用SQL Server / MSDE數據庫。然而它是反射每一個數據庫調用的,這帶來很嚴重的性能影響。這個類雖然仍然還保留著,但很明顯的我們鼓勵開發者采用DataProvider的模式。

?

?

參考

?????? 微軟ASP.NET 組的Rob Howard提供了大量的指導和DataProvider模型實現的示例代碼,.NET Pet Shop 3.0也提供了很多優秀的參考資料。Microsoft Data Access Application Block一個快速開發SQL Server Provider實現的一個有效的工具。

轉載于:https://www.cnblogs.com/Alaric/archive/2011/12/23/2299787.html

總結

以上是生活随笔為你收集整理的DNN 数据访问策略 (转)的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国产精品高潮呻吟av久久4虎 | 性欧美熟妇videofreesex | 人妻少妇精品无码专区动漫 | 亚洲大尺度无码无码专区 | 亚洲中文字幕乱码av波多ji | 天天做天天爱天天爽综合网 | 国产片av国语在线观看 | 亚洲精品午夜国产va久久成人 | 人妻与老人中文字幕 | 娇妻被黑人粗大高潮白浆 | 日产国产精品亚洲系列 | 丰满少妇弄高潮了www | 少妇无码一区二区二三区 | 亚洲成a人一区二区三区 | 无码国产乱人伦偷精品视频 | 欧美兽交xxxx×视频 | 亚洲日本va中文字幕 | 偷窥日本少妇撒尿chinese | 国产成人无码专区 | 丰满人妻精品国产99aⅴ | 亚洲欧美中文字幕5发布 | 妺妺窝人体色www婷婷 | 午夜精品一区二区三区在线观看 | 高潮毛片无遮挡高清免费 | 国产婷婷色一区二区三区在线 | 国精产品一品二品国精品69xx | 欧美 亚洲 国产 另类 | 在线亚洲高清揄拍自拍一品区 | 国产超级va在线观看视频 | 亚洲a无码综合a国产av中文 | 欧美日韩综合一区二区三区 | 日本www一道久久久免费榴莲 | 国产69精品久久久久app下载 | 亚洲大尺度无码无码专区 | 扒开双腿吃奶呻吟做受视频 | ass日本丰满熟妇pics | 欧美亚洲国产一区二区三区 | 蜜桃无码一区二区三区 | 18禁黄网站男男禁片免费观看 | 久久精品99久久香蕉国产色戒 | 丰满岳乱妇在线观看中字无码 | 成人无码视频在线观看网站 | 日本大香伊一区二区三区 | 无码乱肉视频免费大全合集 | 激情爆乳一区二区三区 | 亚洲区小说区激情区图片区 | 美女扒开屁股让男人桶 | 麻豆精品国产精华精华液好用吗 | 色欲久久久天天天综合网精品 | 人人澡人摸人人添 | 国产九九九九九九九a片 | 99久久精品无码一区二区毛片 | 免费网站看v片在线18禁无码 | 国产麻豆精品精东影业av网站 | 国产成人无码区免费内射一片色欲 | 欧美性猛交xxxx富婆 | 人妻少妇精品视频专区 | 国产精品自产拍在线观看 | 亚洲中文字幕无码中文字在线 | 国产av一区二区精品久久凹凸 | 色综合久久久无码网中文 | 成人精品视频一区二区三区尤物 | 少妇性俱乐部纵欲狂欢电影 | 377p欧洲日本亚洲大胆 | 亚拍精品一区二区三区探花 | 青青草原综合久久大伊人精品 | 精品厕所偷拍各类美女tp嘘嘘 | 中国女人内谢69xxxxxa片 | 亚洲中文字幕无码中文字在线 | 亚洲伊人久久精品影院 | 无码人妻出轨黑人中文字幕 | 熟妇激情内射com | 国产精品毛多多水多 | 熟妇人妻无码xxx视频 | 狠狠噜狠狠狠狠丁香五月 | 正在播放东北夫妻内射 | 狠狠色噜噜狠狠狠7777奇米 | 亚洲人成人无码网www国产 | 久久国产精品萌白酱免费 | 亚洲中文无码av永久不收费 | 成人aaa片一区国产精品 | 日本熟妇人妻xxxxx人hd | 亚洲日本一区二区三区在线 | 男人扒开女人内裤强吻桶进去 | 中文字幕亚洲情99在线 | 亚洲爆乳无码专区 | 欧美日韩一区二区三区自拍 | 男女下面进入的视频免费午夜 | 999久久久国产精品消防器材 | 午夜福利电影 | 曰韩无码二三区中文字幕 | 玩弄少妇高潮ⅹxxxyw | 日本xxxx色视频在线观看免费 | 成人亚洲精品久久久久软件 | 奇米影视888欧美在线观看 | 亚洲天堂2017无码 | 国产精品人妻一区二区三区四 | 国产精品永久免费视频 | 强开小婷嫩苞又嫩又紧视频 | 免费无码的av片在线观看 | v一区无码内射国产 | 又大又硬又黄的免费视频 | 成人欧美一区二区三区黑人免费 | 国产精品亚洲综合色区韩国 | 丰满少妇高潮惨叫视频 | 97资源共享在线视频 | 一本大道久久东京热无码av | 国产激情艳情在线看视频 | 精品无码一区二区三区爱欲 | 国产精品久久久久久久影院 | 国产精品亚洲五月天高清 | 精品久久久久久人妻无码中文字幕 | 国产人妻大战黑人第1集 | 久9re热视频这里只有精品 | 狠狠色噜噜狠狠狠7777奇米 | 国产超级va在线观看视频 | 午夜性刺激在线视频免费 | 日日橹狠狠爱欧美视频 | 国产口爆吞精在线视频 | 亚洲 另类 在线 欧美 制服 | 天下第一社区视频www日本 | 国产一精品一av一免费 | 蜜桃臀无码内射一区二区三区 | 国产凸凹视频一区二区 | 免费国产黄网站在线观看 | 六十路熟妇乱子伦 | 国产精品欧美成人 | 网友自拍区视频精品 | 亚洲自偷自偷在线制服 | 欧美一区二区三区视频在线观看 | aⅴ在线视频男人的天堂 | 日韩精品一区二区av在线 | 精品久久久无码人妻字幂 | 久久久久久久久888 | 东京热一精品无码av | 色综合久久久久综合一本到桃花网 | 国产av人人夜夜澡人人爽麻豆 | 狠狠色欧美亚洲狠狠色www | 亚洲理论电影在线观看 | 亚欧洲精品在线视频免费观看 | 欧洲vodafone精品性 | 亚洲自偷精品视频自拍 | 97无码免费人妻超级碰碰夜夜 | 国产特级毛片aaaaaa高潮流水 | 欧美老妇交乱视频在线观看 | 自拍偷自拍亚洲精品被多人伦好爽 | 97精品国产97久久久久久免费 | 中文字幕日韩精品一区二区三区 | 亚洲精品国产品国语在线观看 | 精品无码av一区二区三区 | 国产亚洲视频中文字幕97精品 | 久久综合狠狠综合久久综合88 | 中文字幕乱妇无码av在线 | 亚洲欧美日韩成人高清在线一区 | 国产成人精品优优av | 日本一区二区更新不卡 | 色综合久久久无码中文字幕 | 在线观看国产一区二区三区 | 天天拍夜夜添久久精品大 | 色综合久久网 | 中文字幕+乱码+中文字幕一区 | 好爽又高潮了毛片免费下载 | 国产精品久久久久久久影院 | 久久综合香蕉国产蜜臀av | 波多野结衣aⅴ在线 | 色情久久久av熟女人妻网站 | 久久久久久久人妻无码中文字幕爆 | 国产精品第一区揄拍无码 | 欧美老人巨大xxxx做受 | 少妇邻居内射在线 | 色欲久久久天天天综合网精品 | 欧美亚洲日韩国产人成在线播放 | 日日橹狠狠爱欧美视频 | 夜先锋av资源网站 | 日韩人妻无码中文字幕视频 | 成 人 网 站国产免费观看 | 欧洲熟妇色 欧美 | 久久zyz资源站无码中文动漫 | 粗大的内捧猛烈进出视频 | 性色欲情网站iwww九文堂 | 99久久精品午夜一区二区 | 亚洲小说图区综合在线 | а√天堂www在线天堂小说 | 天海翼激烈高潮到腰振不止 | 成人欧美一区二区三区 | 97夜夜澡人人爽人人喊中国片 | 日日碰狠狠躁久久躁蜜桃 | 妺妺窝人体色www婷婷 | 日日鲁鲁鲁夜夜爽爽狠狠 | 麻豆精产国品 | 日韩欧美中文字幕在线三区 | 欧美猛少妇色xxxxx | 一个人看的视频www在线 | 中文字幕亚洲情99在线 | 国内精品久久毛片一区二区 | 日日摸日日碰夜夜爽av | 强开小婷嫩苞又嫩又紧视频 | 精品夜夜澡人妻无码av蜜桃 | 国产极品美女高潮无套在线观看 | 精品国产一区二区三区四区 | 内射白嫩少妇超碰 | 亚洲а∨天堂久久精品2021 | 久久综合香蕉国产蜜臀av | 国产精品美女久久久久av爽李琼 | 国产精品欧美成人 | 一本久久a久久精品亚洲 | 国产在线精品一区二区三区直播 | 午夜福利不卡在线视频 | 国产成人精品无码播放 | 欧美老熟妇乱xxxxx | 婷婷综合久久中文字幕蜜桃三电影 | 久久综合九色综合欧美狠狠 | 日韩 欧美 动漫 国产 制服 | 日韩精品a片一区二区三区妖精 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 亚洲色大成网站www国产 | 露脸叫床粗话东北少妇 | 成人性做爰aaa片免费看不忠 | 最新国产麻豆aⅴ精品无码 | 亚洲无人区午夜福利码高清完整版 | 精品无码国产一区二区三区av | 熟女体下毛毛黑森林 | 高潮喷水的毛片 | 久久97精品久久久久久久不卡 | 日韩欧美成人免费观看 | 亚洲七七久久桃花影院 | 六月丁香婷婷色狠狠久久 | 久久99国产综合精品 | 乱人伦人妻中文字幕无码久久网 | 国产69精品久久久久app下载 | 国产精品毛片一区二区 | 国产激情综合五月久久 | 亚洲色欲久久久综合网东京热 | 亚洲国产精华液网站w | 无码精品国产va在线观看dvd | 偷窥村妇洗澡毛毛多 | 国语精品一区二区三区 | 天天躁日日躁狠狠躁免费麻豆 | 婷婷五月综合缴情在线视频 | 福利一区二区三区视频在线观看 | 欧美成人午夜精品久久久 | 超碰97人人射妻 | 国产真实乱对白精彩久久 | 国产人妻大战黑人第1集 | 精品久久综合1区2区3区激情 | 任你躁在线精品免费 | 久久精品视频在线看15 | 中文字幕人妻无码一区二区三区 | 日韩欧美成人免费观看 | 国产特级毛片aaaaaa高潮流水 | 欧美喷潮久久久xxxxx | 亚洲综合精品香蕉久久网 | 日本在线高清不卡免费播放 | 给我免费的视频在线观看 | 日日躁夜夜躁狠狠躁 | 老熟妇仑乱视频一区二区 | 国产口爆吞精在线视频 | 亚洲成a人片在线观看无码3d | 亚洲国产成人av在线观看 | 欧美丰满少妇xxxx性 | 正在播放老肥熟妇露脸 | 97无码免费人妻超级碰碰夜夜 | 97色伦图片97综合影院 | 国产亚洲欧美日韩亚洲中文色 | 国产区女主播在线观看 | 免费无码一区二区三区蜜桃大 | 好爽又高潮了毛片免费下载 | 伊人久久大香线蕉av一区二区 | 久久99精品国产.久久久久 | ass日本丰满熟妇pics | 欧美三级不卡在线观看 | 中文字幕av无码一区二区三区电影 | 久久久久av无码免费网 | 中文字幕无码人妻少妇免费 | 久久99精品久久久久久 | 精品一区二区三区波多野结衣 | 久久久国产一区二区三区 | 小sao货水好多真紧h无码视频 | 少妇被黑人到高潮喷出白浆 | 熟女少妇在线视频播放 | 一本久道久久综合狠狠爱 | 国产极品美女高潮无套在线观看 | 亚洲中文无码av永久不收费 | 久久精品国产99久久6动漫 | 内射巨臀欧美在线视频 | 无套内谢老熟女 | 人妻少妇被猛烈进入中文字幕 | 国产成人久久精品流白浆 | 日欧一片内射va在线影院 | 欧美第一黄网免费网站 | 波多野结衣一区二区三区av免费 | 亚洲精品国偷拍自产在线观看蜜桃 | 日韩精品a片一区二区三区妖精 | 久久综合色之久久综合 | 欧美日本免费一区二区三区 | 午夜肉伦伦影院 | 久久综合久久自在自线精品自 | 国产精品久久久一区二区三区 | 又粗又大又硬毛片免费看 | 蜜臀aⅴ国产精品久久久国产老师 | 少妇人妻偷人精品无码视频 | 国产精品福利视频导航 | 中文字幕人妻无码一夲道 | 97久久超碰中文字幕 | 亚洲色欲色欲天天天www | 国产人成高清在线视频99最全资源 | 中文无码伦av中文字幕 | 日本大香伊一区二区三区 | 欧美日韩亚洲国产精品 | 亚洲精品综合一区二区三区在线 | 国产精品福利视频导航 | 亚洲精品国产品国语在线观看 | 高清国产亚洲精品自在久久 | 亚洲一区二区三区在线观看网站 | 牲欲强的熟妇农村老妇女视频 | 精品无人国产偷自产在线 | 影音先锋中文字幕无码 | 欧美日韩视频无码一区二区三 | 一区二区传媒有限公司 | www国产精品内射老师 | 国产成人精品一区二区在线小狼 | 亚洲中文字幕无码中字 | 久久天天躁夜夜躁狠狠 | 久久久久久a亚洲欧洲av冫 | 国产精品无码mv在线观看 | 东京一本一道一二三区 | 亚洲综合精品香蕉久久网 | 蜜桃av抽搐高潮一区二区 | 亚洲熟熟妇xxxx | 亚洲精品中文字幕久久久久 | 久久久精品成人免费观看 | 欧美放荡的少妇 | 妺妺窝人体色www在线小说 | 成人性做爰aaa片免费看 | 亚洲人亚洲人成电影网站色 | 人妻无码久久精品人妻 | 天堂久久天堂av色综合 | 亚洲国产精品无码久久久久高潮 | 国产精品国产三级国产专播 | 国产乱码精品一品二品 | 色综合久久久久综合一本到桃花网 | 亚洲日韩精品欧美一区二区 | 色一情一乱一伦一视频免费看 | 老子影院午夜伦不卡 | 久久久国产精品无码免费专区 | 国产手机在线αⅴ片无码观看 | 精品久久久无码人妻字幂 | 国产精品无码一区二区桃花视频 | 国产真实夫妇视频 | 在线播放免费人成毛片乱码 | 日韩视频 中文字幕 视频一区 | 成人欧美一区二区三区 | 国产精品无码永久免费888 | 亚洲国产精品一区二区美利坚 | 国产成人无码区免费内射一片色欲 | 人妻体内射精一区二区三四 | 日本在线高清不卡免费播放 | www国产精品内射老师 | 亚洲精品午夜无码电影网 | 亚洲一区av无码专区在线观看 | 麻豆国产人妻欲求不满谁演的 | 九九热爱视频精品 | 2020最新国产自产精品 | 亚洲成av人综合在线观看 | 国产两女互慰高潮视频在线观看 | 内射欧美老妇wbb | 久久综合久久自在自线精品自 | 人人妻人人澡人人爽欧美一区 | 人人妻人人藻人人爽欧美一区 | 亚洲经典千人经典日产 | 国产真实夫妇视频 | 亚洲一区二区三区无码久久 | 18禁止看的免费污网站 | 精品久久久无码人妻字幂 | 高清国产亚洲精品自在久久 | 无码人妻少妇伦在线电影 | 国产亚洲欧美在线专区 | 中国女人内谢69xxxxxa片 | 人妻少妇精品视频专区 | 免费观看激色视频网站 | 麻豆国产人妻欲求不满谁演的 | 欧美亚洲日韩国产人成在线播放 | 久热国产vs视频在线观看 | 亚洲精品一区国产 | 国产精品二区一区二区aⅴ污介绍 | 亲嘴扒胸摸屁股激烈网站 | 亚洲无人区午夜福利码高清完整版 | 久久综合色之久久综合 | 亚洲无人区午夜福利码高清完整版 | 性欧美大战久久久久久久 | 色欲久久久天天天综合网精品 | 久久综合九色综合97网 | 国产亚av手机在线观看 | 精品国产精品久久一区免费式 | 高清不卡一区二区三区 | 日日噜噜噜噜夜夜爽亚洲精品 | 伊人久久婷婷五月综合97色 | 久久人人97超碰a片精品 | 麻豆人妻少妇精品无码专区 | 人人妻人人澡人人爽欧美一区 | 牲欲强的熟妇农村老妇女 | 兔费看少妇性l交大片免费 | 99re在线播放 | 亚洲日韩av一区二区三区中文 | 亚洲乱码国产乱码精品精 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 又粗又大又硬又长又爽 | 久久久久久亚洲精品a片成人 | 国产精品多人p群无码 | 亚洲国产精品无码一区二区三区 | 欧美一区二区三区视频在线观看 | 丰满人妻精品国产99aⅴ | 日本xxxx色视频在线观看免费 | 亚洲乱亚洲乱妇50p | 无码人妻丰满熟妇区毛片18 | 久久无码专区国产精品s | 红桃av一区二区三区在线无码av | 亚洲国精产品一二二线 | 久久综合给合久久狠狠狠97色 | 国产精品久久久午夜夜伦鲁鲁 | 又色又爽又黄的美女裸体网站 | 亚洲国产精品无码久久久久高潮 | 日韩少妇内射免费播放 | 少妇高潮一区二区三区99 | 久久精品国产大片免费观看 | 性做久久久久久久久 | 亚洲精品成a人在线观看 | 999久久久国产精品消防器材 | 最新版天堂资源中文官网 | av人摸人人人澡人人超碰下载 | 亚洲精品国产第一综合99久久 | 欧美日本精品一区二区三区 | 粉嫩少妇内射浓精videos | 色妞www精品免费视频 | 精品无码av一区二区三区 | 国产亚洲日韩欧美另类第八页 | 老头边吃奶边弄进去呻吟 | 亚洲色成人中文字幕网站 | 日韩人妻无码中文字幕视频 | 亚洲国产精品一区二区美利坚 | 亚洲国产av美女网站 | 波多野结衣一区二区三区av免费 | 欧美野外疯狂做受xxxx高潮 | 97色伦图片97综合影院 | 亚洲国产欧美国产综合一区 | 成人aaa片一区国产精品 | 中文字幕色婷婷在线视频 | 日韩无套无码精品 | 国产精品久久久久久亚洲影视内衣 | 无码一区二区三区在线观看 | 男人扒开女人内裤强吻桶进去 | 色欲久久久天天天综合网精品 | 久久99精品国产麻豆 | 荫蒂被男人添的好舒服爽免费视频 | 中文字幕乱码亚洲无线三区 | 老司机亚洲精品影院 | 鲁鲁鲁爽爽爽在线视频观看 | 好男人www社区 | 国产亚洲日韩欧美另类第八页 | 天干天干啦夜天干天2017 | 国产乱人无码伦av在线a | 99er热精品视频 | 国产偷自视频区视频 | 2019nv天堂香蕉在线观看 | 天天拍夜夜添久久精品 | 国产婷婷色一区二区三区在线 | 久久午夜无码鲁丝片 | 日产国产精品亚洲系列 | 成年女人永久免费看片 | 久久国产精品精品国产色婷婷 | 无码午夜成人1000部免费视频 | 欧美老妇交乱视频在线观看 | 一本加勒比波多野结衣 | 日韩 欧美 动漫 国产 制服 | 无码免费一区二区三区 | 黑人巨大精品欧美黑寡妇 | 人人澡人人透人人爽 | 无套内谢老熟女 | 久久国产36精品色熟妇 | 亚洲熟悉妇女xxx妇女av | 亚洲午夜久久久影院 | 国产精品亚洲五月天高清 | 国产又爽又猛又粗的视频a片 | 亚洲国产av精品一区二区蜜芽 | 99视频精品全部免费免费观看 | 人人妻人人澡人人爽精品欧美 | 丰腴饱满的极品熟妇 | 女人被爽到呻吟gif动态图视看 | 黑森林福利视频导航 | 日韩精品乱码av一区二区 | 中文字幕无码免费久久99 | 小sao货水好多真紧h无码视频 | 蜜桃视频插满18在线观看 | 双乳奶水饱满少妇呻吟 | 久久久久se色偷偷亚洲精品av | 老子影院午夜精品无码 | 丰满人妻一区二区三区免费视频 | 国产精品人人爽人人做我的可爱 | 亚洲日韩中文字幕在线播放 | 国产成人av免费观看 | 性色欲情网站iwww九文堂 | 国产精品永久免费视频 | 欧美成人午夜精品久久久 | 免费乱码人妻系列无码专区 | 亚洲精品无码人妻无码 | 国产精品久久久久无码av色戒 | 无码av免费一区二区三区试看 | 国产精品鲁鲁鲁 | 国产极品美女高潮无套在线观看 | 亚洲精品一区国产 | 免费无码的av片在线观看 | 免费无码的av片在线观看 | 中文字幕乱码中文乱码51精品 | 色欲av亚洲一区无码少妇 | 福利一区二区三区视频在线观看 | 久久午夜无码鲁丝片 | 欧美人与善在线com | 成人动漫在线观看 | 国产尤物精品视频 | 欧美 日韩 人妻 高清 中文 | 亚洲欧美日韩综合久久久 | 亚洲日本一区二区三区在线 | 久久久久se色偷偷亚洲精品av | 精品国产一区二区三区四区在线看 | 中文久久乱码一区二区 | 亚洲啪av永久无码精品放毛片 | 午夜不卡av免费 一本久久a久久精品vr综合 | a片免费视频在线观看 | 丰满肥臀大屁股熟妇激情视频 | 两性色午夜视频免费播放 | 国产无遮挡又黄又爽免费视频 | 无码人妻少妇伦在线电影 | 最近中文2019字幕第二页 | 水蜜桃亚洲一二三四在线 | 又黄又爽又色的视频 | 国产99久久精品一区二区 | 久久综合给合久久狠狠狠97色 | 18禁黄网站男男禁片免费观看 | 国产免费观看黄av片 | 性色av无码免费一区二区三区 | 欧美性色19p | 在线观看免费人成视频 | 网友自拍区视频精品 | 水蜜桃色314在线观看 | 精品厕所偷拍各类美女tp嘘嘘 | 无码人妻av免费一区二区三区 | 久热国产vs视频在线观看 | 成人av无码一区二区三区 | 好男人社区资源 | 久久亚洲中文字幕无码 | 国产成人精品无码播放 | 日韩欧美中文字幕公布 | 97精品人妻一区二区三区香蕉 | 亚洲一区二区三区偷拍女厕 | 又大又紧又粉嫩18p少妇 | 亚洲自偷自拍另类第1页 | 日韩欧美中文字幕公布 | 色婷婷av一区二区三区之红樱桃 | 亚洲色无码一区二区三区 | 欧美freesex黑人又粗又大 | 精品人人妻人人澡人人爽人人 | av在线亚洲欧洲日产一区二区 | 中国女人内谢69xxxx | 日本爽爽爽爽爽爽在线观看免 | 国内丰满熟女出轨videos | 亚洲成色在线综合网站 | 欧美日韩一区二区综合 | 天海翼激烈高潮到腰振不止 | 国产精品国产三级国产专播 | 国产免费久久精品国产传媒 | 国产农村妇女高潮大叫 | 蜜桃无码一区二区三区 | 亚洲中文字幕在线观看 | 青青草原综合久久大伊人精品 | 久久精品女人的天堂av | aⅴ亚洲 日韩 色 图网站 播放 | 一本大道伊人av久久综合 | 国产偷自视频区视频 | 免费网站看v片在线18禁无码 | 又色又爽又黄的美女裸体网站 | 日韩欧美群交p片內射中文 | 少妇太爽了在线观看 | 欧美日本精品一区二区三区 | a片免费视频在线观看 | 国产sm调教视频在线观看 | 暴力强奷在线播放无码 | 人妻无码αv中文字幕久久琪琪布 | 精品国产成人一区二区三区 | аⅴ资源天堂资源库在线 | 色婷婷香蕉在线一区二区 | 久久久久久av无码免费看大片 | 久久国产自偷自偷免费一区调 | 色一情一乱一伦一视频免费看 | 国产性生交xxxxx无码 | 日韩av无码一区二区三区 | 亚洲 a v无 码免 费 成 人 a v | 在线播放无码字幕亚洲 | 久久99精品久久久久婷婷 | 亚洲精品一区二区三区在线观看 | 黑人大群体交免费视频 | 人妻少妇被猛烈进入中文字幕 | 精品国产青草久久久久福利 | 精品久久久久久人妻无码中文字幕 | 乱人伦人妻中文字幕无码久久网 | 内射老妇bbwx0c0ck | 性欧美牲交在线视频 | 好屌草这里只有精品 | 久久www免费人成人片 | 欧美熟妇另类久久久久久多毛 | 麻豆国产人妻欲求不满谁演的 | 桃花色综合影院 | 偷窥日本少妇撒尿chinese | 中文久久乱码一区二区 | 日本乱偷人妻中文字幕 | 国产莉萝无码av在线播放 | 综合人妻久久一区二区精品 | 国产精品理论片在线观看 | 久久久久久九九精品久 | 男人的天堂2018无码 | 天堂无码人妻精品一区二区三区 | 精品一二三区久久aaa片 | 性色欲网站人妻丰满中文久久不卡 | 国产激情精品一区二区三区 | 国产亚洲tv在线观看 | 国产精品第一国产精品 | 亚洲精品久久久久久一区二区 | 国内精品人妻无码久久久影院 | 天堂在线观看www | 精品aⅴ一区二区三区 | 国产欧美熟妇另类久久久 | 国产高清不卡无码视频 | 成人免费视频一区二区 | 永久免费观看国产裸体美女 | 国产特级毛片aaaaaaa高清 | 人人妻人人澡人人爽欧美一区 | 在线观看免费人成视频 | 国产超级va在线观看视频 | 亚洲啪av永久无码精品放毛片 | 亚洲欧洲日本综合aⅴ在线 | 在线a亚洲视频播放在线观看 | 亚洲阿v天堂在线 | 免费人成在线观看网站 | 女人被男人爽到呻吟的视频 | 亚洲娇小与黑人巨大交 | 少妇人妻av毛片在线看 | 欧美 亚洲 国产 另类 | 麻豆av传媒蜜桃天美传媒 | 欧美日本日韩 | 无码一区二区三区在线观看 | 日本精品久久久久中文字幕 | 欧美人与动性行为视频 | 国产极品美女高潮无套在线观看 | 欧美国产日产一区二区 | 成人动漫在线观看 | 亚洲国精产品一二二线 | 精品久久久中文字幕人妻 | 久久精品人人做人人综合试看 | 最近的中文字幕在线看视频 | 国产精品a成v人在线播放 | аⅴ资源天堂资源库在线 | 久久亚洲中文字幕无码 | 少妇邻居内射在线 | 国产精品手机免费 | 丰满岳乱妇在线观看中字无码 | 中文字幕乱码中文乱码51精品 | 熟女俱乐部五十路六十路av | 国产97色在线 | 免 | 亚洲欧美综合区丁香五月小说 | 帮老师解开蕾丝奶罩吸乳网站 | 国产在线一区二区三区四区五区 | 欧美高清在线精品一区 | 久久久久99精品成人片 | 日产精品高潮呻吟av久久 | 久久伊人色av天堂九九小黄鸭 | 国产农村妇女高潮大叫 | 色综合久久网 | 国产精品亚洲专区无码不卡 | 精品人妻人人做人人爽夜夜爽 | 精品一区二区三区波多野结衣 | 中文字幕av伊人av无码av | 欧美变态另类xxxx | 免费观看的无遮挡av | 国产在热线精品视频 | 国产超级va在线观看视频 | 人人妻人人澡人人爽欧美一区九九 | 久久久久se色偷偷亚洲精品av | 特黄特色大片免费播放器图片 | 欧美人与禽zoz0性伦交 | 欧美亚洲日韩国产人成在线播放 | 亚洲理论电影在线观看 | 成 人 网 站国产免费观看 | 午夜福利不卡在线视频 | 久久久久久av无码免费看大片 | 水蜜桃色314在线观看 | 国语精品一区二区三区 | 人人妻人人澡人人爽人人精品浪潮 | 日日天干夜夜狠狠爱 | 亚洲性无码av中文字幕 | 7777奇米四色成人眼影 | 88国产精品欧美一区二区三区 | 夫妻免费无码v看片 | 高潮毛片无遮挡高清免费视频 | 撕开奶罩揉吮奶头视频 | 国产色视频一区二区三区 | 日本又色又爽又黄的a片18禁 | 四虎国产精品一区二区 | 久热国产vs视频在线观看 | 亚洲中文字幕无码一久久区 | 乌克兰少妇性做爰 | 无遮挡国产高潮视频免费观看 | 永久免费观看美女裸体的网站 | 亚洲精品一区二区三区大桥未久 | 亚洲 a v无 码免 费 成 人 a v | 99视频精品全部免费免费观看 | 无码精品国产va在线观看dvd | 亚洲综合久久一区二区 | 九月婷婷人人澡人人添人人爽 | 大肉大捧一进一出视频出来呀 | 免费网站看v片在线18禁无码 | 性色欲情网站iwww九文堂 | 午夜福利一区二区三区在线观看 | 精品乱子伦一区二区三区 | 久久国产精品_国产精品 | 亚洲人亚洲人成电影网站色 | 无码任你躁久久久久久久 | 国产无遮挡又黄又爽又色 | 午夜精品久久久久久久久 | 中文字幕乱码人妻无码久久 | 中文字幕亚洲情99在线 | 久久精品女人的天堂av | 久久精品国产大片免费观看 | 又粗又大又硬毛片免费看 | 国产精品99久久精品爆乳 | 波多野结衣一区二区三区av免费 | 国产综合久久久久鬼色 | 久久99精品久久久久久 | 曰本女人与公拘交酡免费视频 | 国产高清不卡无码视频 | 亚洲精品中文字幕久久久久 | 激情五月综合色婷婷一区二区 | 最新国产麻豆aⅴ精品无码 | 亚洲爆乳无码专区 | 亚洲欧美日韩成人高清在线一区 | 国产极品美女高潮无套在线观看 | 国产午夜福利100集发布 | 久久精品国产一区二区三区肥胖 | 色一情一乱一伦一区二区三欧美 | 中文毛片无遮挡高清免费 | 午夜肉伦伦影院 | 人人超人人超碰超国产 | 久热国产vs视频在线观看 | 国产精品久久久久久亚洲影视内衣 | 99精品国产综合久久久久五月天 | 男女性色大片免费网站 | 日日摸天天摸爽爽狠狠97 | 国产内射爽爽大片视频社区在线 | 一二三四社区在线中文视频 | 永久免费观看美女裸体的网站 | 欧美精品免费观看二区 | 国产精品美女久久久 | 少妇高潮喷潮久久久影院 | 亚洲精品中文字幕乱码 | 无码人妻出轨黑人中文字幕 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 学生妹亚洲一区二区 | 亚洲欧美精品伊人久久 | 欧美日韩在线亚洲综合国产人 | 99精品无人区乱码1区2区3区 | 国产乡下妇女做爰 | 精品人妻人人做人人爽夜夜爽 | 少妇人妻偷人精品无码视频 | 99久久亚洲精品无码毛片 | 18无码粉嫩小泬无套在线观看 | 最近中文2019字幕第二页 | 中文字幕av伊人av无码av | 大胆欧美熟妇xx | 亚洲色www成人永久网址 | 亚洲国产一区二区三区在线观看 | 久久亚洲日韩精品一区二区三区 | 一本久久a久久精品亚洲 | 亚洲成熟女人毛毛耸耸多 | √8天堂资源地址中文在线 | 亚洲娇小与黑人巨大交 | 国产精品嫩草久久久久 | 帮老师解开蕾丝奶罩吸乳网站 | 日本精品人妻无码免费大全 | 自拍偷自拍亚洲精品被多人伦好爽 | 久久久亚洲欧洲日产国码αv | 在线成人www免费观看视频 | 风流少妇按摩来高潮 | 国产特级毛片aaaaaaa高清 | 国产超碰人人爽人人做人人添 | 亚洲aⅴ无码成人网站国产app | 国产农村妇女高潮大叫 | 久久综合久久自在自线精品自 | 久久国产自偷自偷免费一区调 | 全黄性性激高免费视频 | 永久免费观看美女裸体的网站 | 免费乱码人妻系列无码专区 | 国产精品久久久久无码av色戒 | 午夜成人1000部免费视频 | 亚洲大尺度无码无码专区 | 久久久久成人片免费观看蜜芽 | 国产成人无码av在线影院 | 国产绳艺sm调教室论坛 | 久久久久人妻一区精品色欧美 | 中国大陆精品视频xxxx | a在线观看免费网站大全 | 无码帝国www无码专区色综合 | 婷婷五月综合缴情在线视频 | 久久综合给久久狠狠97色 | 亚洲成av人综合在线观看 | 一本大道久久东京热无码av | 精品国产aⅴ无码一区二区 | 国产情侣作爱视频免费观看 | 99久久久无码国产aaa精品 | 98国产精品综合一区二区三区 | 欧美第一黄网免费网站 | 亚洲精品综合一区二区三区在线 | 亚洲 激情 小说 另类 欧美 | 国产一区二区三区影院 | 久久99国产综合精品 | 18黄暴禁片在线观看 | 无码人妻丰满熟妇区五十路百度 | 又大又硬又黄的免费视频 | 国产午夜亚洲精品不卡下载 | 中文字幕av无码一区二区三区电影 | 国产性生大片免费观看性 | 国产黑色丝袜在线播放 | 成人欧美一区二区三区黑人 | 激情五月综合色婷婷一区二区 | 台湾无码一区二区 | 老太婆性杂交欧美肥老太 | 青青青爽视频在线观看 | 亚洲精品国产a久久久久久 | 色综合久久久久综合一本到桃花网 | 小泽玛莉亚一区二区视频在线 | 国产在线无码精品电影网 | 亚洲精品综合五月久久小说 | 装睡被陌生人摸出水好爽 | 国产精品香蕉在线观看 | 麻豆蜜桃av蜜臀av色欲av | 在线观看免费人成视频 | 国产午夜亚洲精品不卡 | 77777熟女视频在线观看 а天堂中文在线官网 | 高潮毛片无遮挡高清免费视频 | yw尤物av无码国产在线观看 | 欧美日韩一区二区免费视频 | 激情内射亚州一区二区三区爱妻 | 无码帝国www无码专区色综合 | 国产亚洲人成a在线v网站 | 亚洲七七久久桃花影院 | 亚洲中文字幕无码一久久区 | 97夜夜澡人人爽人人喊中国片 | а√资源新版在线天堂 | 亚洲精品综合五月久久小说 | 免费看少妇作爱视频 | 国产9 9在线 | 中文 | 欧美大屁股xxxxhd黑色 | 无码人妻少妇伦在线电影 | 国产一区二区三区日韩精品 | 18无码粉嫩小泬无套在线观看 | 国产在线无码精品电影网 | 免费中文字幕日韩欧美 | 蜜臀aⅴ国产精品久久久国产老师 | 久久久中文字幕日本无吗 | v一区无码内射国产 | 国产人妻精品午夜福利免费 | 人妻插b视频一区二区三区 | 亚洲成av人影院在线观看 | 国产真实伦对白全集 | 亚洲精品综合一区二区三区在线 | 自拍偷自拍亚洲精品被多人伦好爽 | 欧美freesex黑人又粗又大 | 亚洲日韩av片在线观看 | 丰满少妇熟乱xxxxx视频 | 久久久精品成人免费观看 | 婷婷五月综合激情中文字幕 | 狂野欧美性猛交免费视频 | 狠狠噜狠狠狠狠丁香五月 | 国产精品二区一区二区aⅴ污介绍 | 中文精品无码中文字幕无码专区 | 日本乱人伦片中文三区 | 成人精品天堂一区二区三区 | 亚洲日本va中文字幕 | 麻豆国产人妻欲求不满 | 色一情一乱一伦一区二区三欧美 | 白嫩日本少妇做爰 | 久久久久免费看成人影片 | 欧美一区二区三区视频在线观看 | 性做久久久久久久免费看 | 精品欧美一区二区三区久久久 | 精品人人妻人人澡人人爽人人 | www成人国产高清内射 | 国产精品亚洲专区无码不卡 | 未满成年国产在线观看 | 亚洲狠狠婷婷综合久久 | 欧美老妇交乱视频在线观看 | 久久人人爽人人爽人人片av高清 | 激情亚洲一区国产精品 | 好男人www社区 | 精品aⅴ一区二区三区 | 亚洲精品一区二区三区大桥未久 | 无码午夜成人1000部免费视频 | 最近中文2019字幕第二页 | 天堂久久天堂av色综合 | 国内精品九九久久久精品 | 日韩精品无码一本二本三本色 | 中文字幕无码乱人伦 | 成 人 免费观看网站 | 强开小婷嫩苞又嫩又紧视频 | 久久精品视频在线看15 | 超碰97人人做人人爱少妇 | 国产精品无码mv在线观看 | 无码一区二区三区在线 | 正在播放老肥熟妇露脸 | 天堂在线观看www | 亚洲一区二区三区在线观看网站 | 人妻少妇精品无码专区二区 | 国产区女主播在线观看 | 色噜噜亚洲男人的天堂 | 免费播放一区二区三区 | 国内综合精品午夜久久资源 | 粉嫩少妇内射浓精videos | 亚洲精品久久久久中文第一幕 | 亚洲啪av永久无码精品放毛片 | 国产成人精品无码播放 | 亚洲中文字幕无码中字 | 丰满肥臀大屁股熟妇激情视频 | √8天堂资源地址中文在线 | 99久久久国产精品无码免费 | av无码不卡在线观看免费 | 国产午夜无码精品免费看 | 特级做a爰片毛片免费69 | 亚洲天堂2017无码中文 | 色诱久久久久综合网ywww | 欧美老妇与禽交 | 精品人妻人人做人人爽 | 久热国产vs视频在线观看 | 日韩人妻少妇一区二区三区 | 兔费看少妇性l交大片免费 | 乱人伦人妻中文字幕无码久久网 | 亚洲熟熟妇xxxx | 国产精品久久久午夜夜伦鲁鲁 | 久久国产精品二国产精品 | 亚洲va中文字幕无码久久不卡 | 黑人玩弄人妻中文在线 | 国产肉丝袜在线观看 | 精品少妇爆乳无码av无码专区 | 动漫av一区二区在线观看 | 日韩精品a片一区二区三区妖精 | 国产又粗又硬又大爽黄老大爷视 | 亚洲精品综合一区二区三区在线 | 国产一区二区三区四区五区加勒比 | 精品无人区无码乱码毛片国产 | 高中生自慰www网站 | 中文字幕日产无线码一区 | 无码国模国产在线观看 | 无码任你躁久久久久久久 | 在线а√天堂中文官网 | 欧美性生交xxxxx久久久 | 大屁股大乳丰满人妻 | 国产内射爽爽大片视频社区在线 | 欧美日韩一区二区综合 | 十八禁视频网站在线观看 | 久久综合久久自在自线精品自 | 日韩av无码中文无码电影 | 国产精品欧美成人 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲小说图区综合在线 | 熟女少妇在线视频播放 | 丁香花在线影院观看在线播放 | 搡女人真爽免费视频大全 | 青草青草久热国产精品 | 5858s亚洲色大成网站www | 成人片黄网站色大片免费观看 | 全球成人中文在线 | 午夜精品一区二区三区的区别 | 国产香蕉97碰碰久久人人 | 精品一二三区久久aaa片 | 伦伦影院午夜理论片 | 久久国产精品偷任你爽任你 | 无码乱肉视频免费大全合集 | 玩弄人妻少妇500系列视频 | 免费观看的无遮挡av | 人妻aⅴ无码一区二区三区 | 免费国产黄网站在线观看 | 亚洲午夜福利在线观看 | 国产精品亚洲а∨无码播放麻豆 | 亚洲日本在线电影 | aa片在线观看视频在线播放 | 亚洲精品一区国产 | 国产激情无码一区二区 | 97夜夜澡人人双人人人喊 | 永久免费观看美女裸体的网站 | 久久国产自偷自偷免费一区调 | 熟妇激情内射com | 男人和女人高潮免费网站 | 天堂在线观看www | 红桃av一区二区三区在线无码av | 2020久久香蕉国产线看观看 | 欧洲美熟女乱又伦 | 亚洲成a人片在线观看无码 | 国产黄在线观看免费观看不卡 | 在线欧美精品一区二区三区 | 久久综合网欧美色妞网 | 国产午夜亚洲精品不卡下载 | 欧美三级a做爰在线观看 | 久久久精品欧美一区二区免费 | 国产av一区二区精品久久凹凸 | 久久人人97超碰a片精品 | a片免费视频在线观看 | 免费人成在线视频无码 | 在线欧美精品一区二区三区 | 日韩欧美群交p片內射中文 | 国内精品久久久久久中文字幕 | 亚洲日韩av一区二区三区中文 | 波多野结衣一区二区三区av免费 | 日本欧美一区二区三区乱码 | 色老头在线一区二区三区 | 色 综合 欧美 亚洲 国产 | 国产在线无码精品电影网 | 综合人妻久久一区二区精品 | 国产麻豆精品一区二区三区v视界 | 天天综合网天天综合色 | 最新国产麻豆aⅴ精品无码 | 国产精品美女久久久 | 亚洲国产高清在线观看视频 | 蜜桃无码一区二区三区 | 国产无遮挡又黄又爽又色 | 国产午夜无码视频在线观看 | 成 人 网 站国产免费观看 | 欧美丰满少妇xxxx性 | 亚洲色大成网站www国产 | 天干天干啦夜天干天2017 | 风流少妇按摩来高潮 | 性啪啪chinese东北女人 | 啦啦啦www在线观看免费视频 | 国产激情无码一区二区app | 亚洲人交乣女bbw | 亚洲一区二区观看播放 | 98国产精品综合一区二区三区 | 性色欲情网站iwww九文堂 | 日日摸夜夜摸狠狠摸婷婷 | 377p欧洲日本亚洲大胆 | 人妻互换免费中文字幕 | 久在线观看福利视频 | 在线播放无码字幕亚洲 | 久久人人97超碰a片精品 | a国产一区二区免费入口 | 爱做久久久久久 | 久久综合久久自在自线精品自 | 亚洲阿v天堂在线 | 人妻少妇精品视频专区 | 国产精品久久精品三级 | 老熟女重囗味hdxx69 | 久热国产vs视频在线观看 | 人人妻人人澡人人爽精品欧美 | 无码吃奶揉捏奶头高潮视频 | 久久人妻内射无码一区三区 | 玩弄人妻少妇500系列视频 | 午夜福利不卡在线视频 | 亚洲中文字幕在线观看 | 熟女俱乐部五十路六十路av | 夜夜高潮次次欢爽av女 | 免费国产成人高清在线观看网站 | 大胆欧美熟妇xx | 色欲av亚洲一区无码少妇 | 中文无码精品a∨在线观看不卡 | 99久久精品无码一区二区毛片 | 粉嫩少妇内射浓精videos | 欧美亚洲日韩国产人成在线播放 | 大地资源网第二页免费观看 | 欧洲vodafone精品性 | 丰满诱人的人妻3 | 久久精品中文字幕大胸 | а√资源新版在线天堂 | 亚洲欧美日韩国产精品一区二区 | 无码免费一区二区三区 | 黑人粗大猛烈进出高潮视频 | 久久精品女人天堂av免费观看 | 大地资源中文第3页 | 国产一区二区三区四区五区加勒比 | 天堂一区人妻无码 | 欧美一区二区三区 | 午夜不卡av免费 一本久久a久久精品vr综合 | 国产福利视频一区二区 | 日韩av激情在线观看 | 久久午夜夜伦鲁鲁片无码免费 | 国产偷抇久久精品a片69 | 国产乱人偷精品人妻a片 | 欧美日韩色另类综合 | 久久久成人毛片无码 | 成年美女黄网站色大免费视频 | 亚洲综合无码一区二区三区 | 强开小婷嫩苞又嫩又紧视频 | aⅴ亚洲 日韩 色 图网站 播放 | 人人妻人人澡人人爽欧美一区九九 | 久久久亚洲欧洲日产国码αv | 国产人妻人伦精品 | 欧美真人作爱免费视频 | 人人妻人人藻人人爽欧美一区 | 婷婷五月综合缴情在线视频 | 国产在线精品一区二区三区直播 | 狂野欧美性猛交免费视频 | 国产绳艺sm调教室论坛 | 大肉大捧一进一出好爽视频 | 色综合久久久无码中文字幕 | 欧美丰满熟妇xxxx性ppx人交 | 亚洲精品久久久久avwww潮水 | 极品嫩模高潮叫床 | 日日碰狠狠丁香久燥 | 久久这里只有精品视频9 | 国产一区二区三区日韩精品 | 无遮无挡爽爽免费视频 | 精品国产乱码久久久久乱码 | 老太婆性杂交欧美肥老太 | 奇米影视7777久久精品 | 人人妻人人澡人人爽人人精品 | 欧美亚洲日韩国产人成在线播放 | 激情亚洲一区国产精品 | 国产精品va在线观看无码 | 久久午夜夜伦鲁鲁片无码免费 | 国产黄在线观看免费观看不卡 | 亚洲欧美综合区丁香五月小说 | 一本色道久久综合狠狠躁 | a片免费视频在线观看 | 无遮挡啪啪摇乳动态图 | 麻豆人妻少妇精品无码专区 | 麻豆精品国产精华精华液好用吗 | 老司机亚洲精品影院无码 | 日本饥渴人妻欲求不满 | 国产区女主播在线观看 | 女人和拘做爰正片视频 | 精品久久久无码中文字幕 | 国产 浪潮av性色四虎 | 中文久久乱码一区二区 | 精品偷拍一区二区三区在线看 | 国产精品va在线观看无码 | 亚洲s码欧洲m码国产av | 麻豆国产人妻欲求不满 | 国内精品人妻无码久久久影院 | 国产精品二区一区二区aⅴ污介绍 | 51国偷自产一区二区三区 | 欧美老妇交乱视频在线观看 | 婷婷五月综合缴情在线视频 | 伊人久久大香线蕉av一区二区 | 欧洲熟妇精品视频 | 久久久久av无码免费网 | 精品国产成人一区二区三区 | 久久综合狠狠综合久久综合88 | 亚洲国产精品久久久天堂 | 福利一区二区三区视频在线观看 | 久久精品女人的天堂av | 国产精品亚洲专区无码不卡 | 成人欧美一区二区三区黑人免费 | 欧美xxxx黑人又粗又长 | 日产国产精品亚洲系列 | 亚洲精品久久久久久一区二区 | 97夜夜澡人人爽人人喊中国片 | yw尤物av无码国产在线观看 | 四虎4hu永久免费 | 国产高清不卡无码视频 | 日韩视频 中文字幕 视频一区 | 中文亚洲成a人片在线观看 | 波多野结衣高清一区二区三区 | 久久亚洲国产成人精品性色 | 日本丰满熟妇videos | 久久久国产一区二区三区 | 精品无人国产偷自产在线 | 国产卡一卡二卡三 | 亚洲人成影院在线观看 | 99精品无人区乱码1区2区3区 | 强奷人妻日本中文字幕 | 色欲综合久久中文字幕网 | 女人色极品影院 | 红桃av一区二区三区在线无码av | 天天爽夜夜爽夜夜爽 | 欧美日韩一区二区免费视频 | 人妻少妇被猛烈进入中文字幕 | 少妇人妻偷人精品无码视频 | 好屌草这里只有精品 | 中文字幕无码免费久久9一区9 | 亚洲成av人综合在线观看 | 天堂一区人妻无码 | 国产人成高清在线视频99最全资源 | 中文字幕无码人妻少妇免费 | 国产一精品一av一免费 | 精品人妻中文字幕有码在线 | 国产亚洲精品久久久久久久久动漫 | 夜精品a片一区二区三区无码白浆 | 无码精品人妻一区二区三区av | 精品国产青草久久久久福利 | 日韩精品无码一区二区中文字幕 | 国产精品久久久av久久久 | 亚洲欧美国产精品专区久久 | 国产熟妇另类久久久久 | 成人一在线视频日韩国产 | 青春草在线视频免费观看 | 一本一道久久综合久久 | a国产一区二区免费入口 | 亚洲热妇无码av在线播放 | 国产精品毛多多水多 | 国产成人精品一区二区在线小狼 | 九九在线中文字幕无码 | 领导边摸边吃奶边做爽在线观看 | 日产国产精品亚洲系列 | 国产精品美女久久久网av | 亚洲色欲久久久综合网东京热 | 亚洲精品一区二区三区四区五区 | 六月丁香婷婷色狠狠久久 | 丰满人妻精品国产99aⅴ | 国产性生交xxxxx无码 | 亚洲国产成人av在线观看 | 丰满护士巨好爽好大乳 | 亚洲色欲色欲天天天www | 精品熟女少妇av免费观看 | 精品国产福利一区二区 | 欧美老妇与禽交 | 窝窝午夜理论片影院 | 无码人妻少妇伦在线电影 | av小次郎收藏 | 亚洲国产综合无码一区 | 日本免费一区二区三区最新 | 成人免费视频视频在线观看 免费 | 日本肉体xxxx裸交 | 欧美国产亚洲日韩在线二区 | 中文字幕无码免费久久9一区9 | 老熟妇仑乱视频一区二区 | av小次郎收藏 | 欧美国产日韩亚洲中文 | 亚洲毛片av日韩av无码 | 无码吃奶揉捏奶头高潮视频 | 成人免费无码大片a毛片 | 欧美日韩亚洲国产精品 | 风流少妇按摩来高潮 | 国产乱人伦av在线无码 | 欧美 亚洲 国产 另类 | 精品国产一区二区三区av 性色 | 午夜免费福利小电影 | 色一情一乱一伦一区二区三欧美 | 亚洲成a人一区二区三区 | 日本肉体xxxx裸交 | 一区二区三区乱码在线 | 欧洲 | 日本欧美一区二区三区乱码 | 色妞www精品免费视频 | 亚洲国产精品美女久久久久 | 国内精品久久毛片一区二区 | 少妇太爽了在线观看 | 天干天干啦夜天干天2017 | 欧美高清在线精品一区 | 久久亚洲中文字幕无码 | 精品国精品国产自在久国产87 | 亚洲精品一区二区三区四区五区 | 国产成人无码专区 | 免费人成在线观看网站 | 精品乱码久久久久久久 | 免费中文字幕日韩欧美 | 台湾无码一区二区 | 成人三级无码视频在线观看 | 免费播放一区二区三区 | 成人免费无码大片a毛片 | 国产精品国产三级国产专播 | 亚洲国产综合无码一区 | 97久久精品无码一区二区 | 男女作爱免费网站 | 久9re热视频这里只有精品 | 未满成年国产在线观看 | 亚洲中文字幕无码中文字在线 | 国产成人无码午夜视频在线观看 | 巨爆乳无码视频在线观看 | 福利一区二区三区视频在线观看 | 久久久久免费精品国产 | 日韩人妻无码一区二区三区久久99 | 日产国产精品亚洲系列 | 国产精品无码mv在线观看 | 亚洲七七久久桃花影院 | 国产亚洲精品精品国产亚洲综合 | 欧美日韩一区二区三区自拍 | 精品国产乱码久久久久乱码 | 国产亚av手机在线观看 | 午夜时刻免费入口 | 国产农村乱对白刺激视频 | 欧美第一黄网免费网站 | 成在人线av无码免观看麻豆 | 国产精品毛片一区二区 | 又湿又紧又大又爽a视频国产 | 18黄暴禁片在线观看 | 性欧美疯狂xxxxbbbb | 日本va欧美va欧美va精品 | 国产亚洲人成a在线v网站 | 少妇无码一区二区二三区 | 亚洲一区二区三区国产精华液 | 在线 国产 欧美 亚洲 天堂 | 成人无码精品一区二区三区 | 久久国产精品二国产精品 | 精品久久久无码中文字幕 | 亚洲一区二区三区国产精华液 | 国产人妻精品午夜福利免费 | 久久 国产 尿 小便 嘘嘘 | 久久精品国产一区二区三区肥胖 | 亚洲人成网站色7799 | 国产色在线 | 国产 | 国产午夜无码视频在线观看 | a国产一区二区免费入口 | 欧美日韩一区二区免费视频 | 午夜精品一区二区三区在线观看 | 国产精品视频免费播放 | 强伦人妻一区二区三区视频18 | 久久国产36精品色熟妇 | 呦交小u女精品视频 | 亚洲乱码中文字幕在线 | 日本熟妇乱子伦xxxx | 性色欲情网站iwww九文堂 | 清纯唯美经典一区二区 | 成人三级无码视频在线观看 | 久久国内精品自在自线 | 国产莉萝无码av在线播放 | 国产精品久久久久久亚洲影视内衣 | 欧美xxxx黑人又粗又长 | 亚洲高清偷拍一区二区三区 | 国产精品国产自线拍免费软件 | 国产尤物精品视频 | 国产午夜亚洲精品不卡下载 | 一本色道久久综合亚洲精品不卡 | 亚洲精品国产品国语在线观看 | 人妻熟女一区 | 亚洲va欧美va天堂v国产综合 | 黑人巨大精品欧美黑寡妇 | 无码精品国产va在线观看dvd | 久久综合激激的五月天 | 国色天香社区在线视频 | 精品乱子伦一区二区三区 | 丰满妇女强制高潮18xxxx | 国产精品亚洲а∨无码播放麻豆 | 永久免费精品精品永久-夜色 | 1000部夫妻午夜免费 | 少妇久久久久久人妻无码 | 久久久久人妻一区精品色欧美 | 中文字幕中文有码在线 | 亚洲熟悉妇女xxx妇女av | 给我免费的视频在线观看 | 中文字幕无码av激情不卡 | 国产后入清纯学生妹 | 日韩欧美成人免费观看 | 亚洲日韩一区二区三区 | 久久久国产精品无码免费专区 | 在线播放免费人成毛片乱码 | 欧美阿v高清资源不卡在线播放 | 少妇无码吹潮 | 国内精品人妻无码久久久影院 | 在线 国产 欧美 亚洲 天堂 | 欧美精品免费观看二区 | 99久久久无码国产aaa精品 | 一本久道高清无码视频 | 国产香蕉尹人综合在线观看 | 亚洲中文字幕乱码av波多ji | 日本丰满熟妇videos | 在线亚洲高清揄拍自拍一品区 | 人人妻人人澡人人爽人人精品浪潮 | 色五月五月丁香亚洲综合网 | 樱花草在线社区www | 天堂在线观看www | 一个人免费观看的www视频 | 高潮毛片无遮挡高清免费 | 东北女人啪啪对白 | 丰满少妇高潮惨叫视频 | 午夜不卡av免费 一本久久a久久精品vr综合 | 国产精品手机免费 | 久久精品成人欧美大片 | 秋霞成人午夜鲁丝一区二区三区 | 人人澡人人妻人人爽人人蜜桃 | 香港三级日本三级妇三级 | 亚洲 另类 在线 欧美 制服 | 亚洲va中文字幕无码久久不卡 | 免费人成在线视频无码 | 老熟妇乱子伦牲交视频 | 亚洲国产av美女网站 | 久久精品丝袜高跟鞋 | 岛国片人妻三上悠亚 | 精品成在人线av无码免费看 | 99久久婷婷国产综合精品青草免费 | 在线欧美精品一区二区三区 | 夜夜影院未满十八勿进 | 天堂一区人妻无码 | 狠狠色色综合网站 | 久久精品中文字幕一区 | 欧美色就是色 | 女人被男人爽到呻吟的视频 | 蜜臀aⅴ国产精品久久久国产老师 | 乱码午夜-极国产极内射 | 东京一本一道一二三区 | 少妇性l交大片 | 人妻插b视频一区二区三区 | 亚洲毛片av日韩av无码 | 亚洲一区二区三区香蕉 | 亚洲成在人网站无码天堂 | 99riav国产精品视频 | 亚洲va欧美va天堂v国产综合 | 国内揄拍国内精品少妇国语 | 国产婷婷色一区二区三区在线 | 国产无套粉嫩白浆在线 | 久久久久se色偷偷亚洲精品av | 色综合视频一区二区三区 | 青春草在线视频免费观看 | 久久久久成人片免费观看蜜芽 | 国产成人综合美国十次 | 国产精品久久国产精品99 | 国产亚洲人成a在线v网站 | 国产艳妇av在线观看果冻传媒 | 荫蒂被男人添的好舒服爽免费视频 | 久久亚洲日韩精品一区二区三区 | 亚洲色大成网站www国产 | 暴力强奷在线播放无码 | 精品人妻av区 | 日本乱偷人妻中文字幕 | 国产在线无码精品电影网 | 亚洲日韩一区二区三区 | 国产人妻久久精品二区三区老狼 | 中文字幕人成乱码熟女app | 天堂无码人妻精品一区二区三区 | 欧美日韩精品 | 水蜜桃亚洲一二三四在线 | 狠狠噜狠狠狠狠丁香五月 | 大乳丰满人妻中文字幕日本 | 无码人妻出轨黑人中文字幕 | 国产sm调教视频在线观看 | 成人无码视频免费播放 | 亚洲午夜久久久影院 | 色综合视频一区二区三区 | 激情内射亚州一区二区三区爱妻 | 日日摸天天摸爽爽狠狠97 | 久久久亚洲欧洲日产国码αv | 国产精品沙发午睡系列 | 亚洲乱码中文字幕在线 | 美女黄网站人色视频免费国产 | 久久久亚洲欧洲日产国码αv | 亚洲经典千人经典日产 | 精品人妻av区 | 国产疯狂伦交大片 | 377p欧洲日本亚洲大胆 | 久久综合给合久久狠狠狠97色 | 一本一道久久综合久久 | 在线天堂新版最新版在线8 | 日韩人妻无码一区二区三区久久99 | 激情内射亚州一区二区三区爱妻 | 亚洲欧美色中文字幕在线 | www国产精品内射老师 | 在线成人www免费观看视频 | 秋霞成人午夜鲁丝一区二区三区 | 国产人妖乱国产精品人妖 | 亚洲成av人在线观看网址 | 亚洲狠狠色丁香婷婷综合 | 狂野欧美性猛交免费视频 | 麻花豆传媒剧国产免费mv在线 | 国产亚洲精品久久久久久久久动漫 | 人妻aⅴ无码一区二区三区 | 国产精品无码mv在线观看 | 国产精品亚洲一区二区三区喷水 | 日日噜噜噜噜夜夜爽亚洲精品 | 在线看片无码永久免费视频 | 日韩人妻无码一区二区三区久久99 | 婷婷五月综合激情中文字幕 | 精品国产青草久久久久福利 | 亚洲色欲色欲欲www在线 | 麻豆精品国产精华精华液好用吗 | 日本爽爽爽爽爽爽在线观看免 | 久久久精品456亚洲影院 | 亚洲国产欧美日韩精品一区二区三区 | 久久精品人妻少妇一区二区三区 | 久久人人爽人人人人片 | 最近的中文字幕在线看视频 | 丰满少妇女裸体bbw | 亚洲人成影院在线无码按摩店 | 国产精品毛多多水多 | 成人毛片一区二区 | 大地资源中文第3页 | 男人和女人高潮免费网站 | 亚洲欧美精品aaaaaa片 | 国产成人久久精品流白浆 | 国产精品久久国产精品99 | 久久久精品国产sm最大网站 | 久久久久99精品国产片 | 亚洲精品久久久久久久久久久 | 亚洲精品久久久久avwww潮水 | 亚洲国产成人av在线观看 | www成人国产高清内射 | 中文亚洲成a人片在线观看 | 噜噜噜亚洲色成人网站 | 色诱久久久久综合网ywww | 丰满人妻一区二区三区免费视频 | 好男人社区资源 | 国产激情综合五月久久 | 亚洲中文字幕久久无码 | 天天摸天天碰天天添 | 亚洲熟妇色xxxxx欧美老妇y | 亚洲啪av永久无码精品放毛片 | 少妇久久久久久人妻无码 | 亚洲欧洲中文日韩av乱码 | 内射欧美老妇wbb | 亚洲乱亚洲乱妇50p | 国产免费观看黄av片 | 国产美女极度色诱视频www | 日本熟妇人妻xxxxx人hd | 人人妻人人澡人人爽人人精品 | 欧美精品在线观看 | 精品一区二区不卡无码av | 精品偷拍一区二区三区在线看 | 国产女主播喷水视频在线观看 | 欧美精品一区二区精品久久 | 亚洲色在线无码国产精品不卡 | 最近免费中文字幕中文高清百度 | av在线亚洲欧洲日产一区二区 | 人妻有码中文字幕在线 | 欧美日本日韩 | 免费乱码人妻系列无码专区 | 无码午夜成人1000部免费视频 | 国内精品人妻无码久久久影院 | 成人女人看片免费视频放人 | 国产真实伦对白全集 | 狠狠色噜噜狠狠狠7777奇米 | 欧美精品一区二区精品久久 | 久久久精品人妻久久影视 | 大肉大捧一进一出视频出来呀 | 久久亚洲中文字幕无码 | 精品久久久久久人妻无码中文字幕 | 精品乱码久久久久久久 | 中文字幕乱码中文乱码51精品 | 欧美日韩一区二区综合 | 乱中年女人伦av三区 | 全黄性性激高免费视频 | 午夜理论片yy44880影院 | 国产午夜精品一区二区三区嫩草 | 99久久精品日本一区二区免费 | 国产9 9在线 | 中文 | 日欧一片内射va在线影院 | 国产欧美熟妇另类久久久 | 国产亚洲精品久久久久久国模美 | 无码人妻丰满熟妇区五十路百度 | 98国产精品综合一区二区三区 | 久久99精品久久久久久 | 一本久久a久久精品vr综合 | 国产黑色丝袜在线播放 | 俄罗斯老熟妇色xxxx | 欧美高清在线精品一区 | 日本高清一区免费中文视频 | 玩弄中年熟妇正在播放 | 久久亚洲国产成人精品性色 | 国产午夜手机精彩视频 | 亚洲成色www久久网站 | 国产香蕉尹人视频在线 | 巨爆乳无码视频在线观看 | 天天爽夜夜爽夜夜爽 | 牲欲强的熟妇农村老妇女视频 | 欧美乱妇无乱码大黄a片 | 久久午夜无码鲁丝片秋霞 | 久久久婷婷五月亚洲97号色 | 99久久精品午夜一区二区 | 99久久人妻精品免费一区 | 国产做国产爱免费视频 | 亚洲狠狠色丁香婷婷综合 | 国产成人一区二区三区在线观看 | 精品aⅴ一区二区三区 | 亚欧洲精品在线视频免费观看 | 国产乱人伦偷精品视频 | 狠狠色丁香久久婷婷综合五月 | 国产色精品久久人妻 | 少妇太爽了在线观看 | 宝宝好涨水快流出来免费视频 | 免费无码午夜福利片69 | 99riav国产精品视频 | 国产高潮视频在线观看 | 小sao货水好多真紧h无码视频 | 精品国偷自产在线视频 | 久久久中文字幕日本无吗 | 久久亚洲中文字幕精品一区 | 亚洲精品一区二区三区大桥未久 | 国产黑色丝袜在线播放 | 精品偷自拍另类在线观看 | 99精品视频在线观看免费 | 国产精品自产拍在线观看 | 国产精品永久免费视频 | 国产成人无码av一区二区 | yw尤物av无码国产在线观看 | 999久久久国产精品消防器材 | 丰满少妇人妻久久久久久 | 亚洲日韩av片在线观看 | 51国偷自产一区二区三区 | 精品人人妻人人澡人人爽人人 | 久久99精品国产麻豆 | 夜夜高潮次次欢爽av女 | 精品国产一区二区三区av 性色 | 欧美人妻一区二区三区 | 成人一区二区免费视频 | 国产精品高潮呻吟av久久 | 樱花草在线社区www | 任你躁国产自任一区二区三区 | 大色综合色综合网站 | 国产精华av午夜在线观看 | 欧美成人家庭影院 | 亚洲毛片av日韩av无码 | 清纯唯美经典一区二区 | 人人超人人超碰超国产 | 亚洲欧美日韩国产精品一区二区 | 无码人妻精品一区二区三区下载 | 色婷婷综合激情综在线播放 | 亚洲一区二区三区在线观看网站 | 色婷婷欧美在线播放内射 | 成人女人看片免费视频放人 | 无码吃奶揉捏奶头高潮视频 | 波多野结衣乳巨码无在线观看 | 激情内射日本一区二区三区 | 国产人妻精品一区二区三区不卡 | 鲁一鲁av2019在线 | 久久国产精品偷任你爽任你 | 伊在人天堂亚洲香蕉精品区 | 中文毛片无遮挡高清免费 | 日韩亚洲欧美中文高清在线 | 欧美精品免费观看二区 | 国模大胆一区二区三区 | 丰满肥臀大屁股熟妇激情视频 | 国产小呦泬泬99精品 | 亚洲精品一区二区三区大桥未久 | 波多野结衣av在线观看 | 粉嫩少妇内射浓精videos | 国产卡一卡二卡三 | 国产亚洲精品久久久久久久 | 国产精品久久福利网站 | 亚洲精品国产第一综合99久久 | 大地资源网第二页免费观看 | 亚洲国产精品久久久天堂 | 亚洲精品一区三区三区在线观看 | 国产乱人偷精品人妻a片 | 大肉大捧一进一出视频出来呀 | 国产乱人伦偷精品视频 | 男人的天堂av网站 | 日本一卡二卡不卡视频查询 | 噜噜噜亚洲色成人网站 | 国内揄拍国内精品少妇国语 | 亚洲国产精华液网站w | 色诱久久久久综合网ywww | 亚洲男女内射在线播放 | 图片区 小说区 区 亚洲五月 | 嫩b人妻精品一区二区三区 | 亚洲精品一区二区三区婷婷月 | 欧美人与牲动交xxxx | 亚洲人成影院在线无码按摩店 | 无码人妻少妇伦在线电影 | 亚洲第一网站男人都懂 | 撕开奶罩揉吮奶头视频 | 天天av天天av天天透 | 波多野结衣av一区二区全免费观看 | 捆绑白丝粉色jk震动捧喷白浆 | 亚洲aⅴ无码成人网站国产app | 日本欧美一区二区三区乱码 | 女人高潮内射99精品 | 自拍偷自拍亚洲精品10p | 极品尤物被啪到呻吟喷水 | 国产后入清纯学生妹 | 国产莉萝无码av在线播放 | 亚洲综合无码久久精品综合 | 女人被男人躁得好爽免费视频 | 亚洲码国产精品高潮在线 | 欧美日韩精品 | 欧美成人免费全部网站 | 人人妻人人澡人人爽欧美一区九九 | 国内精品九九久久久精品 | 亚洲日韩乱码中文无码蜜桃臀网站 | 亚洲欧美精品伊人久久 | 亚洲乱码中文字幕在线 | 3d动漫精品啪啪一区二区中 | 国内精品久久久久久中文字幕 | 无码纯肉视频在线观看 | 国产精品二区一区二区aⅴ污介绍 | 欧美国产亚洲日韩在线二区 | 曰韩无码二三区中文字幕 |