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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

EntityFramework Core如何映射动态模型?

發(fā)布時間:2023/12/4 编程问答 49 豆豆
生活随笔 收集整理的這篇文章主要介紹了 EntityFramework Core如何映射动态模型? 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
【導(dǎo)讀】本文我們來探討下映射動態(tài)模型的幾種方式,相信一部分童鞋項目有這樣的需求,比如每天/每小時等生成一張表,此種動態(tài)模型映射非常常見,經(jīng)我摸索,這里給出每一步詳細(xì)思路,希望能幫助到?jīng)]有任何頭緒的童鞋

本文以.NET Core 3.1控制臺,同時以SQL Server數(shù)據(jù)庫作為示例演示(其他數(shù)據(jù)庫同理照搬),由于會用到內(nèi)置APi,因版本不同可能比如構(gòu)造函數(shù)需略微進(jìn)行調(diào)整即可。

注:雖為示例代碼,但我將其作為實際項目皆已進(jìn)行封裝,基本完全通用。本文略長(約5334字),請耐心。

動態(tài)映射模型引入前提

首先我們給出所需要用到的特性以及對應(yīng)枚舉,看注釋一看便知

public?enum?CustomTableFormat {///?<summary>///?每天,(yyyyMMdd)///?</summary>[Description("每天")]DAY,///?<summary>///?每小時,(yyyyMMddHH)///?</summary>[Description("每小時")]HOUR,///?<summary>///?每分鐘(yyyyMMddHHmm)///?</summary>[Description("每分鐘")]MINUTE }[AttributeUsage(AttributeTargets.Class,?AllowMultiple?=?false)] public?class?EfEntityAttribute?:?Attribute {///?<summary>///?是否啟用動態(tài)生成表///?</summary>public?bool?EnableCustomTable?{?get;?set;?}?=?false;///?<summary>///?動態(tài)生成表前綴///?</summary>public?string?Prefix?{?get;?set;?}///?<summary>///?表生成規(guī)則///?</summary>public?CustomTableFormat?Format?{?get;?set;?}?=?CustomTableFormat.DAY;public?override?string?ToString(){if?(EnableCustomTable){return?string.IsNullOrEmpty(Prefix)???Format.FormatToDate()?:?$"{Prefix}{Format.FormatToDate()}";}return?base.ToString();} }public?static?class?CustomTableFormatExetension {public?static?string?FormatToDate(this?CustomTableFormat?tableFormat){return?tableFormat?switch{CustomTableFormat.DAY?=>?DateTime.Now.ToString("yyyyMMdd"),CustomTableFormat.HOUR?=>?DateTime.Now.ToString("yyyyMMddHH"),CustomTableFormat.MINUTE?=>?DateTime.Now.ToString("yyyyMMddHHmm"),_?=>?DateTime.Now.ToString("yyyyMMdd"),};} }

通過定義特性,主要出發(fā)點基于以下兩點:

其一:由外部注入模型而非寫死DbSet屬性訪問

其二:每個模型可定義動態(tài)映射表規(guī)則

動態(tài)映射模型方式(一)

首先我們給出需要用到的上下文,為方便演示我們以每分鐘自動映射模型為例

public?class?EfDbContext?:?DbContext {public?string?Date?{?get;?set;?}?=?CustomTableFormat.MINUTE.FormatToDate();public?EfDbContext(DbContextOptions<EfDbContext>?options)?:?base(options){} }

動態(tài)模型即指表名不同,比如我們實現(xiàn)每天/每小時/每分鐘動態(tài)映射模型和生成一張表,如同流動的水一樣并非一層不變,但本質(zhì)上還是那滴水。在下面接口中我們需要用到每分鐘生成一張表格式,所以在上下文中定義每分鐘屬性

第一種方式則是通過實現(xiàn)IModelCacheKeyFactory接口,此接口將指定上下文下所有模型表名進(jìn)行了緩存,所以我們可以根據(jù)所需動態(tài)模型表名進(jìn)行更改即可,如下:

public?class?CustomModelCacheKeyFactory?:?IModelCacheKeyFactory {public?object?Create(DbContext?context){var?efDbContext?=?context?as?EfDbContext;if?(efDbContext?!=?null){return?(context.GetType(),?efDbContext.Date);}return?context.GetType();} }

上述其實現(xiàn)貌似感覺有點看不太懂,主要這是直接實現(xiàn)接口一步到位,底層本質(zhì)則是額外調(diào)用實例一個緩存鍵類,我們將上述改為如下兩步則一目了然

public?class?CustomModelCacheKeyFactory?:?ModelCacheKeyFactory {private?string?_date;public?CustomModelCacheKeyFactory(ModelCacheKeyFactoryDependencies?dependencies):?base(dependencies){}public?override?object?Create(DbContext?context){if?(context?is?EfDbContext?efDbContext){_date?=?efDbContext.Date;}return?new?CustomModelCacheKey(_date,?context);} }public?class?CustomModelCacheKey?:?ModelCacheKey {private?readonly?Type?_contextType;private?readonly?string?_date;public?CustomModelCacheKey(string?date,?DbContext?context)?:?base(context){_date?=?date;_contextType?=?context.GetType();}public?virtual?bool?Equals(CustomModelCacheKey?other)=>?_contextType?==?other._contextType?&&?_date?==?other._date;public?override?bool?Equals(object?obj)=>?(obj?is?CustomModelCacheKey?otherAsKey)?&&?Equals(otherAsKey);public?override?int?GetHashCode()?=>?_date.GetHashCode(); }

然后在OnModelCreating方法里面進(jìn)行掃描特性標(biāo)識模型進(jìn)行注冊,如下:

protected?override?void?OnModelCreating(ModelBuilder?modelBuilder) {var?entityMethod?=?typeof(ModelBuilder).GetMethod(nameof(modelBuilder.Entity),?new?Type[]?{?});var?assembly?=?Assembly.GetExecutingAssembly();//【1】使用Entity方法注冊foreach?(var?type?in?assembly.ExportedTypes){if?(!(type.GetCustomAttribute(typeof(EfEntityAttribute))?is?EfEntityAttribute?attribute)){continue;}if?(type.IsNotPublic?||?type.IsAbstract?||?type.IsSealed||?type.IsGenericType||?type.ContainsGenericParameters){continue;}entityMethod.MakeGenericMethod(type).Invoke(modelBuilder,?new?object[]?{?});}//【2】使用IEntityTypeConfiguration<T>注冊modelBuilder.ApplyConfigurationsFromAssembly(assembly);base.OnModelCreating(modelBuilder); }

上述第一種方式則通過反射將模型注冊,其本質(zhì)則是調(diào)用modeBuilder.Entity方法,若我們在模型上使用注解,則對應(yīng)也會將其應(yīng)用

但注解不夠靈活,比如要標(biāo)識聯(lián)合主鍵,則只能使用Fluent APi,所以我們通過在外部實現(xiàn)IEntityTypeConfiguration進(jìn)行注冊,然后EF Core提供針對該接口程序集注冊,其底層本質(zhì)也是掃描程序集,兩種方式都支持,不用再擔(dān)心外部模型注冊問題

緊接著我們給出測試模型,表名為當(dāng)前分鐘,表名利用注解則不行(值必須為常量),所以我們使用如下第二種映射模型

[EfEntity(EnableCustomTable?=?true,?Format?=?CustomTableFormat.MINUTE)] public?class?Test {[Table(DateTime.Now.ToString("yyyyMMdd"))]public?int?Id?{?get;?set;?}public?string?Name?{?get;?set;?} }public?class?TestEntityTypeConfiguration?:?IEntityTypeConfiguration<Test> {public?void?Configure(EntityTypeBuilder<Test>?builder){builder.ToTable(DateTime.Now.ToString("yyyyMMddHHmm"));} }

上述第二種配置未嘗不可,但我們還有更加簡潔一步到位的操作,所以這里刪除上述第二種方式

因為在OnModelCreating方法里面,我們反射了調(diào)用了Entity方法,所以我們直接將反射調(diào)用Entity方法強制轉(zhuǎn)換為EntityTypeBuilder,在已有基礎(chǔ)上,代碼做了重點標(biāo)識

protected?override?void?OnModelCreating(ModelBuilder?modelBuilder) {var?entityMethod?=?typeof(ModelBuilder).GetMethod(nameof(modelBuilder.Entity),?new?Type[]?{?});var?assembly?=?Assembly.GetExecutingAssembly();//【1】使用Entity方法注冊foreach?(var?type?in?assembly.ExportedTypes){if?(!(type.GetCustomAttribute(typeof(EfEntityAttribute))?is?EfEntityAttribute?attribute)){continue;}if?(type.IsNotPublic?||?type.IsAbstract?||?type.IsSealed||?type.IsGenericType||?type.ContainsGenericParameters){continue;}//?強制轉(zhuǎn)換為EntityTypeBuildervar?entityBuilder?=?(EntityTypeBuilder)entityMethod.MakeGenericMethod(type).Invoke(modelBuilder,?new?object[]?{?});if?(attribute.EnableCustomTable){entityBuilder.ToTable(attribute.ToString());}}//【2】使用IEntityTypeConfiguration<T>注冊modelBuilder.ApplyConfigurationsFromAssembly(assembly);base.OnModelCreating(modelBuilder); }

最后則是注入上下文,這里我們將內(nèi)外部容器進(jìn)行區(qū)分(EF Core為何分內(nèi)部容器,具體原因請參看文章《EntityFramework Core 3.x上下文構(gòu)造函數(shù)可以注入實例呢?》)

因在實際項目中上下文可能需要在上下文構(gòu)造函數(shù)中注入其他接口,比如我們就有可能在上下文構(gòu)造函數(shù)中注入接口從而根據(jù)具體接口實現(xiàn)來更改表架構(gòu)或不同表名規(guī)則等等

static?IServiceProvider?Initialize() {var?services?=?new?ServiceCollection();services.AddEntityFrameworkSqlServer().AddDbContext<EfDbContext>((serviceProvider,?options)?=>options.UseSqlServer("server=.;database=efcore;uid=sa;pwd=sa123;").UseInternalServiceProvider(serviceProvider));services.Replace(ServiceDescriptor.Singleton<IModelCacheKeyFactory,?CustomModelCacheKeyFactory>());return?services.BuildServiceProvider(); }

由于我們已區(qū)分EF Core內(nèi)外部容器,所以在替換自定義緩存鍵工廠時,不能再像如下直接調(diào)用ReplaceService方法替換,勢必會拋出異常

?options.UseSqlServer("server=.;database=efcore;uid=sa;pwd=sa123;").ReplaceService<IModelCacheKeyFactory,?CustomModelCacheKeyFactory>()

同時謹(jǐn)記在非Web項目中利用EF Core始終要使用作用域(scope)來釋放上下文,不像Web可基于HTTP請求作為scope,最后我們測試如下

using?(var?scope1?=?ServiceProvider.CreateScope()) {var?context1?=?scope1.ServiceProvider.GetService<EfDbContext>();context1.Database.EnsureCreated();var?type?=?context1.Model.FindEntityType(typeof(Test));Console.WriteLine(type?.GetTableName());var?tests?=?context1.Set<Test>().ToList(); }Thread.Sleep(60000);using?(var?scope2?=?ServiceProvider.CreateScope()) {var?context2?=?scope2.ServiceProvider.GetService<EfDbContext>();context2.Database.EnsureCreated();var?type?=?context2.Model.FindEntityType(typeof(Test));Console.WriteLine(type?.GetTableName());var?tests1?=?context2.Set<Test>().ToList(); }

為方便看到實際效果,我們構(gòu)建兩個scope,然后睡眠一分鐘,在界面上打印輸出表名,若兩分鐘后打印表名不一致,說明達(dá)到預(yù)期

動態(tài)映射模型方式(二)

上述我們使用每分鐘規(guī)則動態(tài)映射表,同時可針對不同模型有各自規(guī)則(前綴,每小時或每天)等等,這是第一種方式

如果對第一種方式實現(xiàn)完全看懂了,可能會有所疑惑,因為第一種方式其接口生命周期為單例,若不需要豈不還是會將上下文中所有模型都會進(jìn)行緩存嗎

調(diào)用OnModelCreating方法只是進(jìn)行模型構(gòu)建,我們現(xiàn)直接調(diào)用內(nèi)置APi來手動使用所有模型,此時將不再緩存,所以不再需要IModelCacheKeyFactory接口

對EF Core稍微了解一點的話,我們知道OnModelCreating方法僅僅只會調(diào)用一次,我們通過手動構(gòu)構(gòu)建和處置所有模型,說了這么多,那么我們到底該如何做呢?

如果看過我之前原理分析的話,大概能知道EntityFramework Core對于模型的處理(除卻模型緩存)分為三步,除卻模型緩存:構(gòu)建模型,使用模型,處置模型。

我們將OnModelCreating方法代碼全部直接復(fù)制過來,只是多了上面三步而已,在我們實例化ModelBuilder時,我們需要提供對應(yīng)數(shù)據(jù)庫默認(rèn)約定,然后使用模型、處置模型,結(jié)果變成如下這般

?services.AddEntityFrameworkSqlServer().AddDbContext<EfDbContext>((serviceProvider,?options)?=>?{options.UseSqlServer("server=.;database=efcore;uid=sa;pwd=sa123;").UseInternalServiceProvider(serviceProvider);var?conventionSet?=?SqlServerConventionSetBuilder.Build();var?modelBuilder?=?new?ModelBuilder(conventionSet);//?OnModelCreating方法,代碼復(fù)制options.UseModel(modelBuilder.Model);modelBuilder.FinalizeModel();???????????????)};

運行第一種方式測試代碼,然后么有問題

問題來了,要是有多個數(shù)據(jù)庫,豈不是都要像上述再來一遍?上述實現(xiàn)本質(zhì)上是每次構(gòu)造一個上下文則會構(gòu)建并重新使用新的模型,所以我們將其統(tǒng)一放到上下文構(gòu)造函數(shù)中去,然后寫個擴展方法構(gòu)建模型,如下:

public?static?class?ModelBuilderExetension {public?static?ModelBuilder?BuildModel(this?ModelBuilder?modelBuilder){var?entityMethod?=?typeof(ModelBuilder).GetMethod(nameof(modelBuilder.Entity),?new?Type[]?{?});var?assembly?=?Assembly.GetExecutingAssembly();//【1】使用Entity方法注冊foreach?(var?type?in?assembly.ExportedTypes){if?(!(type.GetCustomAttribute(typeof(EfEntityAttribute))?is?EfEntityAttribute?attribute)){continue;}if?(type.IsNotPublic?||?type.IsAbstract?||?type.IsSealed||?type.IsGenericType||?type.ContainsGenericParameters){continue;}var?entityBuilder?=?(EntityTypeBuilder)entityMethod.MakeGenericMethod(type).Invoke(modelBuilder,?new?object[]?{?});if?(attribute.EnableCustomTable){entityBuilder.ToTable(attribute.ToString());}}//【2】使用IEntityTypeConfiguration<T>注冊modelBuilder.ApplyConfigurationsFromAssembly(assembly);return?modelBuilder;} }

最后在上下文構(gòu)造函數(shù)中,簡潔調(diào)用,如下:

public?class?EfDbContext?:?DbContext {public?string?Date?{?get;?set;?}?=?CustomTableFormat.MINUTE.FormatToDate();public?EfDbContext(DbContextOptions<EfDbContext>?options)?:?base(options){//提供不同數(shù)據(jù)庫默認(rèn)約定ConventionSet?conventionSet?=?null;if?(Database.ProviderName?==?"Microsoft.EntityFrameworkCore.SqlServer"){conventionSet?=?SqlServerConventionSetBuilder.Build();}else?if?(Database.ProviderName?==?"Microsoft.EntityFrameworkCore.Sqllite"){conventionSet?=?SqliteConventionSetBuilder.Build();}else?if?(Database.ProviderName?==?"Microsoft.EntityFrameworkCore.MySql"){conventionSet?=?MySqlConventionSetBuilder.Build();}var?modelBuilder?=?new?ModelBuilder(conventionSet);var?optionBuilder?=?new?DbContextOptionsBuilder(options);//使用模型optionBuilder.UseModel(modelBuilder.Model);//處置模型modelBuilder.FinalizeModel();}protected?override?void?OnModelCreating(ModelBuilder?modelBuilder){//構(gòu)建模型modelBuilder.BuildModel();base.OnModelCreating(modelBuilder);} }

動態(tài)映射模型表生成

看到這里,細(xì)心的你不知道有沒有發(fā)現(xiàn),我寫的打印結(jié)果怎么成功了,居然沒拋出任何異常,實際情況是必須會拋出異常,因為我們只做到了模型動態(tài)映射,但表自動生成我在此之前將其忽略了,如下:

表如何生成這個也看實際情況分析,比如SQL Server寫個作業(yè)每天自動生成表等,若需兼容多個數(shù)據(jù)庫,怕是有點麻煩

我沒花太多時間去看源碼,稍微看了下,碰碰運氣或許能直接找到根據(jù)模型來創(chuàng)建表的接口實現(xiàn),結(jié)果好像沒有,即使有也比較麻煩,那么我們就手動構(gòu)建SQL語句或者通過lambda構(gòu)建也可

上下文中實現(xiàn)其特性需動態(tài)生成的模型我們可以獲取得到,然后搞個定時器每分鐘去執(zhí)行生成對應(yīng)表,針對不同數(shù)據(jù)庫類型,我們可以通過如下屬性獲取得到(和包同名)

//?比如SQL Server:Microsoft.EntityFrameworkCore.SqlServer context.Database.ProviderName

這里我以SQL Server數(shù)據(jù)庫為例,其他數(shù)據(jù)庫比如MySqL、Sqlite唯一區(qū)別則是自增長設(shè)置和列類型不同而已,創(chuàng)建表,通過五部分組成:表是否存在,表名,主鍵,所有列,約束。我們定義如下:

internal?sealed?class?CustomTableModel {public?CustomEntityType?CustomEntityType?{?get;?set;?}public?string?TableName?{?get;?set;?}?=?string.Empty;public?string?CheckTable?{?get;?set;?}?=?string.Empty;public?string?PrimaryKey?{?get;?set;?}?=?string.Empty;public?string?Columns?{?get;?set;?}?=?string.Empty;public?string?Constraint?{?get;?set;?}?=?string.Empty;public?override?string?ToString(){var?placeHolder?=?$"{CheckTable}?create?table?{TableName}?({PrimaryKey}?{Columns}";placeHolder?=?string.IsNullOrEmpty(Constraint)???$"{placeHolder.TrimEnd(',')})"?:?$"{placeHolder}{Constraint})";return?placeHolder.Replace("@placeholder_table_name",?CustomEntityType.ToString());} }

由于每次生成只有表名不同,所以我們將整個表數(shù)據(jù)結(jié)構(gòu)進(jìn)行緩存,在其內(nèi)部將表名進(jìn)行替換就好。整個實現(xiàn)邏輯如下:

public?static?void?Execute() {using?var?scope?=?Program.ServiceProvider.CreateScope();var?context?=?scope.ServiceProvider.GetService<EfDbContext>();context.Database.EnsureCreated();var?cache?=?scope.ServiceProvider.GetService<IMemoryCache>();var?cacheKey?=?context.GetType().FullName;if?(!cache.TryGetValue(cacheKey,?out?List<CustomTableModel>?models)){lock?(_syncObject){if?(!cache.TryGetValue(cacheKey,?out?models)){models?=?CreateModels(context);models?=?cache.Set(cacheKey,?models,?new?MemoryCacheEntryOptions?{?Size?=?100,?Priority?=?CacheItemPriority.High?});}}}Create(context,?models); }private?static?void?Create(EfDbContext?context,?List<CustomTableModel>?models) {foreach?(var?m?in?models){context.Execute(m.ToString());} }internal?static?void?CreateEntityTypes(CustomEntityType?customEntityType) {EntityTypes.Add(customEntityType); }

上述標(biāo)紅部分很重要,為什么呢?

讓其先執(zhí)行OnModelCreating方法,也就是說我們必須保證所有模型已經(jīng)構(gòu)建完畢,我們才能在上下文中拿到所有模型元數(shù)據(jù)

接下來則是在OnModeCreating方法中,在啟動自動映射模型的基礎(chǔ)上,添加如下代碼(當(dāng)然也需檢查表名是否存在重復(fù)):

??if?(attribute.EnableCustomTable){entityBuilder.ToTable(attribute.ToString());var?customType?=?new?CustomEntityType(){ClrType?=?type,Prefix?=?attribute.Prefix,Format?=?attribute.Format};var?existTable?=?CreateCustomTable.EntityTypes.FirstOrDefault(c?=>?c.ToString()?==?customType.ToString());if?(existTable?!=?null){throw?new?ArgumentNullException($"Cannot?use?table?'{customType}'?for?entity?type?'{type.Name}'?since?it?is?being?used?for?entity?type?'{existTable.ClrType.Name}'?");}CreateCustomTable.CreateEntityTypes(customType);}

相信構(gòu)建SQL語句這塊都不在話下,就不再給出了,若有需要的童鞋,可私信我,人比較多的話,我會將兼容不同數(shù)據(jù)庫的SQL語句構(gòu)建都會放到github上去以供參考,控制臺入口方法調(diào)用如下:

private?const?int?TIME_INTERVAL_IN_MILLISECONDS?=?60000; private?static?Timer?_timer?{?get;?set;?} public?static?IServiceProvider?ServiceProvider?{?get;?set;?} static?void?Main(string[]?args) {ServiceProvider?=?Initialize();//初始化時檢查一次CreateCustomTable.Execute();//定時檢查_timer?=?new?Timer(TimerCallback,?null,?TIME_INTERVAL_IN_MILLISECONDS,?Timeout.Infinite);using?(var?scope1?=?ServiceProvider.CreateScope()){var?context1?=?scope1.ServiceProvider.GetService<EfDbContext>();context1.Database.EnsureCreated();var?type?=?context1.Model.FindEntityType(typeof(Test1));Console.WriteLine(type?.GetTableName());var?tests?=?context1.Set<Test1>().ToList();}Thread.Sleep(60000);using?(var?scope2?=?ServiceProvider.CreateScope()){var?context2?=?scope2.ServiceProvider.GetService<EfDbContext>();context2.Database.EnsureCreated();var?type?=?context2.Model.FindEntityType(typeof(Test2));Console.WriteLine(type?.GetTableName());var?tests1?=?context2.Set<Test2>().ToList();}Console.ReadKey();}

接下來則是通過定義上述定時器,回調(diào)調(diào)用上述Execute方法,如下:

??static?void?TimerCallback(object?state){var?watch?=?new?Stopwatch();watch.Start();CreateCustomTable.Execute();_timer.Change(Math.Max(0,?TIME_INTERVAL_IN_MILLISECONDS?-?watch.ElapsedMilliseconds),?Timeout.Infinite);}

最后我們來兩個模型測試下實際效果

[EfEntity(EnableCustomTable?=?true,?Prefix?=?"test1",?Format?=?CustomTableFormat.MINUTE)] public?class?Test1 {public?int?Id?{?get;?set;?}public?int?UserId?{?get;?set;?}public?string?Name?{?get;?set;?} }public?class?Test1EntityTypeConfiguration?:?IEntityTypeConfiguration<Test1> {public?void?Configure(EntityTypeBuilder<Test1>?builder){builder.HasKey(k?=>?new?{?k.Id,?k.UserId?});} }[EfEntity(EnableCustomTable?=?true,?Prefix?=?"test2",?Format?=?CustomTableFormat.MINUTE)] public?class?Test2 {public?int?Id?{?get;?set;?}public?int?UserId?{?get;?set;?}public?string?Name?{?get;?set;?} }public?class?Test2EntityTypeConfiguration?:?IEntityTypeConfiguration<Test2> {public?void?Configure(EntityTypeBuilder<Test2>?builder){builder.HasKey(k?=>?new?{?k.Id,?k.UserId?});} }

最后的最后,老規(guī)矩,實現(xiàn)動態(tài)映射模型有如上兩種方式,通過手動構(gòu)建SQL語句并緩存,總結(jié)如下!

??????使用IModelCacheKeyFactory

?????手動構(gòu)建模型、處置模型

???????兼容不同數(shù)據(jù)庫,手動構(gòu)建SQL語句并緩存

總結(jié)

以上是生活随笔為你收集整理的EntityFramework Core如何映射动态模型?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

午夜少妇一区二区三区 | 国产精品福利小视频 | 欧美永久视频 | 天天操综合网 | 国产v亚洲v | 97理论片 | 精品久久91 | 91精品导航 | 探花系列在线 | 四虎在线影视 | 国产一级片免费视频 | 午夜精选视频 | 精品国产一区二区三区久久久蜜月 | 久福利| 欧美日韩国内在线 | av网站大全免费 | 精品国产91亚洲一区二区三区www | 91精品成人久久 | 天天天天综合 | 欧美成人69av| 国产成人一区二区三区在线观看 | 久久精品久久久久久久 | 99在线观看视频 | 久久99久久99 | 99c视频高清免费观看 | 国产精品一区二区三区观看 | 天天爱天天操 | 欧美精品久久久久久久久免 | 欧美最猛性xxxx | 国产福利精品在线观看 | 日韩免| 国产最顶级的黄色片在线免费观看 | 一区二区av | 中文日韩在线 | 欧美一级片在线 | 天天碰天天操视频 | 久久久久久高潮国产精品视 | 精品 一区 在线 | 国产黄色特级片 | 四月婷婷在线观看 | 私人av | 国产在线观看地址 | 成年人网站免费观看 | 国产精品成人一区二区 | 久久综合九色综合久99 | 日韩在线字幕 | 97香蕉久久超级碰碰高清版 | 国产一级大片在线观看 | 精品亚洲免费视频 | www.国产精品 | 久久久久久久久久久久av | 久久精品日产第一区二区三区乱码 | 99精品区 | 日韩大片在线看 | 免费亚洲精品视频 | 成人精品99 | 99综合视频 | 日韩av不卡在线观看 | 99这里只有精品视频 | 国产五月婷婷 | 福利av在线| 久99热| 久久免费观看视频 | 在线观看激情av | a天堂免费| 亚洲激情六月 | 中文字幕亚洲不卡 | 亚洲黄色免费在线看 | 欧美日韩久 | 伊人官网 | 日韩一级片观看 | 中文字幕日韩国产 | 国产亚洲精品福利 | 午夜精品久久久久久99热明星 | 97精品一区二区三区 | 久久综合影音 | 欧美一区二区在线免费观看 | 人人舔人人 | 成年人免费电影在线观看 | 日韩精品一区二区三区在线视频 | 国产视频美女 | 91九色pron| 一区 二区 精品 | 国产手机av | 国产精品国产精品 | 国产美女免费 | 九九久久视频 | 午夜精品视频一区 | 色综合天天爱 | 91精品国产自产在线观看永久 | 国产亚洲成av人片在线观看桃 | 一级淫片在线观看 | 国产一级精品绿帽视频 | 视频一区视频二区在线观看 | 欧美一区二区三区四区夜夜大片 | 草久久久久久久 | 手机在线永久免费观看av片 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 日韩电影在线观看一区二区 | 久久国产一二区 | 国产日韩一区在线 | 欧美日韩免费观看一区二区三区 | 久久久久久毛片精品免费不卡 | 欧美日韩国产精品爽爽 | 欧美日韩裸体免费视频 | 在线视频成人 | 九九久久久 | 丁香五婷 | www.五月天婷婷 | 久草网站在线 | 精品在线亚洲视频 | 久久视频这里有久久精品视频11 | 欧美精品久久久久久久久老牛影院 | 黄色av一区二区 | 伊人五月综合 | 国产精品国产毛片 | 成人影片在线免费观看 | av在线影片 | 在线欧美中文字幕 | 91av片| 色婷婷激情综合 | 日日碰狠狠添天天爽超碰97久久 | 国产福利免费看 | 成年人天堂com | 黄色天堂在线观看 | 欧美俄罗斯性视频 | www.久久com| 久久精品精品电影网 | 91男人影院| 国产香蕉视频在线观看 | 亚洲精品国 | 久久久免费播放 | 国产一区二区三区在线 | 欧美日韩亚洲在线观看 | 丝袜美腿亚洲 | 久久人人爽人人片 | 国产精品美女久久久久久2018 | 超碰99人人 | 成人午夜在线观看 | 韩国精品在线观看 | 亚洲播放一区 | 久久视频热 | 伊香蕉大综综综合久久啪 | 右手影院亚洲欧美 | 五月开心激情网 | 丰满少妇对白在线偷拍 | 亚洲激情视频在线 | 亚洲精品一区二区在线观看 | 97超碰超碰 | 香蕉久久国产 | 日韩理论在线 | 国产精品视频永久免费播放 | 黄色影院在线免费观看 | 国产 色| 特级xxxxx欧美 | 99久久精品国产毛片 | 日本精品一区二区三区在线播放视频 | 久久艹国产 | 99爱在线 | www.伊人网 | 亚洲成av人片在线观看无 | 免费成人结看片 | 黄色大全视频 | 一本一本久久a久久 | 日韩欧美在线不卡 | 丁香九月婷婷综合 | 精品视频中文字幕 | 色综合天天视频在线观看 | 国产成人亚洲在线观看 | 亚洲动漫在线观看 | 色吊丝在线永久观看最新版本 | 国产一级在线观看视频 | 啪一啪在线 | 中文字幕在线观看第二页 | 久久久久久久久久免费视频 | 成年人在线免费看视频 | 黄色www免费 | 午夜av不卡| 国精产品一二三线999 | 人人草在线视频 | 欧美精品一区二区三区一线天视频 | 日韩欧美一区二区三区在线观看 | 9999精品免费视频 | 亚洲免费资源 | 国产一卡在线 | 美女黄视频免费 | 亚洲精品高清在线 | 操老逼免费视频 | 免费视频二区 | 五月综合在线观看 | 久久福利国产 | 婷婷色av | 国产亚洲精品bv在线观看 | 国产日韩在线观看一区 | 国产小视频免费观看 | 天天天色综合 | 久久久人人人 | 97超碰人人模人人人爽人人爱 | 亚洲精品综合久久 | 香蕉视频在线播放 | 日批视频在线播放 | 日韩精品一区二区免费视频 | 亚洲mv大片欧洲mv大片免费 | 国产在线观看,日本 | 欧美韩国日本在线 | 中文字幕日韩精品有码视频 | 亚洲精品在线一区二区 | 精品日韩在线 | 综合久久久久久久久 | 99热精品久久 | 丁香花在线观看视频在线 | 亚洲一级片免费观看 | 97色视频在线 | 国产一区二区三区 在线 | 99精品欧美一区二区三区黑人哦 | 91成人免费观看视频 | 97电影在线观看 | 一级做a爱片性色毛片www | 亚洲日本一区二区在线 | 天天操天天干天天操天天干 | 午夜精品一区二区三区在线视频 | 91原创在线观看 | 久久精品亚洲精品国产欧美 | 视频在线日韩 | 午夜性色| 成年人在线| 白丝av免费观看 | 国产免费嫩草影院 | 波多野结衣动态图 | 91插插视频 | 亚洲一区网站 | 久精品在线观看 | 亚洲成人精品久久久 | 日本mv大片欧洲mv大片 | av在线超碰 | 国产成人不卡 | 欧美日韩三级在线观看 | 丁香六月婷婷开心婷婷网 | 狠狠狠色丁香婷婷综合久久88 | 欧美成亚洲 | 欧美综合久久 | 女人18毛片a级毛片一区二区 | 开心激情综合网 | 国产一级在线 | 二区中文字幕 | 国产精品3区 | 成年人电影免费在线观看 | 六月丁香社区 | 久草热久草视频 | 99热在线国产精品 | 免费网站在线观看人 | 91丨九色丨91啦蝌蚪老版 | 伊人精品在线 | 日韩在线视频免费播放 | 99视频精品视频高清免费 | a级片网站 | 在线看片视频 | 一区二区三区四区不卡 | 一级α片| 欧美激情精品 | 中文字幕免费高清av | 伊人www22综合色 | 九九有精品| 中文字幕永久免费 | 色先锋av资源中文字幕 | 999久久久精品视频 日韩高清www | 九色免费视频 | 欧美a视频 | 精品日韩中文字幕 | 中文字幕在线观看视频免费 | 久草网站在线 | 天天操天天弄 | 99热精品国产一区二区在线观看 | 一区二区三区日韩在线 | 色综合久久久久久久久五月 | 视频在线观看亚洲 | 久久综合9988久久爱 | www色com| 麻豆精品国产传媒 | 国产精品影音先锋 | 成人资源在线播放 | www久久精品 | 蜜臀aⅴ国产精品久久久国产 | 香蕉视频91 | 色婷婷婷| 开心激情综合网 | 日韩最新av在线 | 91黄色影视| www.日本色| 亚洲成av | 国产精品视频在线看 | 亚洲国产影院av久久久久 | 国产精品日韩欧美 | 国产精品视频最多的网站 | 国产精品成人国产乱 | 欧美日韩精品在线观看视频 | 欧美小视频在线 | 国内久久久久 | 国产精品美女网站 | 91九色在线视频 | 亚洲国产精品免费 | 久久a v电影 | 国产青草视频在线观看 | 福利一区二区三区四区 | 97精品国产97久久久久久春色 | 久草综合在线观看 | 久久久久亚洲精品男人的天堂 | 91桃色在线免费观看 | 久久国产二区 | 天天草天天插 | 色91在线视频 | 久久在线精品视频 | 国产精品久久久久久久久久久久 | 日韩av黄 | 亚洲第一av在线播放 | 综合久久婷婷 | 久久99精品国产99久久6尤 | 天天爱天天射天天干天天 | 欧美 激情在线 | 日韩中文字幕视频在线 | 四虎国产精品免费 | 欧美精品在线观看 | 免费观看www7722午夜电影 | 在线导航福利 | 嫩草av影院 | 日韩精品免费在线播放 | 操操综合 | 色a4yy| 日本电影久久 | 国产日韩欧美在线 | 超碰九九 | 久久精彩免费视频 | 欧美日韩中文视频 | 日韩在线视频播放 | 天天综合网入口 | 日本三级中文字幕在线观看 | 国产丝袜一区二区三区 | 欧美日韩高清免费 | 成 人 黄 色 视频免费播放 | 天天在线视频色 | 一区二区激情视频 | 天天爱天天 | 日本久久成人中文字幕电影 | 免费看国产a| 国产视频 亚洲精品 | av在线进入 | 夜夜操网站| av福利免费 | 99久久99久久综合 | 中文在线√天堂 | 国产九九热 | 天天插天天干天天操 | 亚洲更新最快 | 99精品在线免费视频 | 亚洲毛片在线观看. | 亚洲黄色免费观看 | 看国产黄色大片 | 日韩免费小视频 | 久久久久久久久久久电影 | 欧美日韩国产在线精品 | www在线观看视频 | 午夜精品久久久99热福利 | 超碰免费观看 | 99re6热在线精品视频 | 国产精品在线看 | 中文字幕在线免费看 | 成人免费在线看片 | 日日爱av | 亚洲激情五月 | 国产色视频一区二区三区qq号 | 一区二区伦理电影 | 久久久久久久久久久成人 | 亚洲国产三级 | 精品免费视频. | 中文字幕亚洲综合久久五月天色无吗'' | 久久99久久99精品免费看小说 | 久草在线观看 | x99av成人免费| 亚洲精品国产日韩 | 国产精品综合久久久久久 | 国产伦精品一区二区三区在线 | 日韩中文字幕免费看 | 久久新视频 | 天天夜夜狠狠操 | 激情五月综合网 | 亚洲精品看片 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 三级黄色在线 | 天天拍天天色 | 九九久久免费 | 婷婷丁香色 | av日韩中文| 九九久久精品视频 | 国产vs久久 | 成人黄大片视频在线观看 | 中文字幕影片免费在线观看 | 在线观看免费成人 | 不卡av免费在线观看 | 欧美aa级| 国产一区视频免费在线观看 | 久久丁香 | 69精品在线 | 日本精品久久久久中文字幕5 | 欧美性生活免费 | 香蕉视频在线免费 | 一区二区三区三区在线 | 国产精品白丝jk白祙 | 欧美日本不卡视频 | 国内视频1区| 婷婷在线精品视频 | 日日骑 | 日本三级全黄少妇三2023 | 亚洲精品av中文字幕在线在线 | 国产在线精品视频 | 精品国产电影 | 午夜黄网 | 91精品国自产在线 | 91热精品 | 亚洲精品综合在线观看 | 国产福利在线免费 | 亚洲激情久久 | 国产精品国产三级国产aⅴ无密码 | 国产一区国产二区在线观看 | 97精品国产97久久久久久粉红 | 国产淫片| 精品国产不卡 | 免费亚洲电影 | 免费三级在线 | 天天操夜夜操天天射 | 96av视频| 成人小视频在线观看免费 | 久久亚洲婷婷 | 日韩精品久久中文字幕 | 91精品久久香蕉国产线看观看 | 99热播精品 | 中文字幕亚洲欧美日韩 | 久久久久久久久久久免费视频 | www.成人久久 | 99精品久久只有精品 | 欧美伦理电影一区二区 | 亚洲精品www久久久 www国产精品com | 五月天.com | 在线观看一级 | 欧美大片在线观看一区 | 精品特级毛片 | 最新av在线免费观看 | 超碰免费av | 久久久久高清毛片一级 | 免费观看一区二区 | 日本午夜免费福利视频 | 麻豆传媒一区二区 | 国产大片免费久久 | 亚洲婷婷网 | 中文字幕av全部资源www中文字幕在线观看 | 五月导航 | 天天操天天舔天天干 | 色偷偷88888欧美精品久久 | 国产精品第一页在线观看 | 成全免费观看视频 | 久久香蕉影视 | 成人免费视频a | 91亚洲国产 | 亚洲aaa毛片 | 亚洲精品高清视频在线观看 | 91成人免费在线 | 国产一区福利 | 亚洲综合婷婷 | 国产成人99av超碰超爽 | 国产一区二区中文字幕 | 国产美女在线观看 | 黄色免费观看 | 不卡电影一区二区三区 | 成人一区电影 | 亚洲人成网站精品片在线观看 | 在线免费观看国产黄色 | 国产精品久久久久久久久久久杏吧 | 精品国产乱子伦一区二区 | 日韩在线电影一区 | 西西人体www444 | 国产日韩精品在线 | 99欧美| 97精品久久 | av官网在线 | 手机看片中文字幕 | 国产精品亚洲片在线播放 | 99精品视频在线播放观看 | 四虎国产免费 | 在线观看免费国产小视频 | 91久久在线观看 | 91超碰免费在线 | 日本少妇久久久 | 欧美精品网站 | 国产99在线免费 | www国产亚洲精品久久麻豆 | 91国内在线 | 国产原创av片 | 人人爽久久久噜噜噜电影 | 又紧又大又爽精品一区二区 | 精品久久久久久久久久国产 | 免费日韩电影 | 9幺看片| 99久久国产免费免费 | 波多野结衣资源 | 国产无遮挡又黄又爽在线观看 | 日韩欧美成人网 | 91精品入口 | 成人日批视频 | 国产精品成人av电影 | 91精品视频在线 | 成人动漫精品一区二区 | 久久精品亚洲精品国产欧美 | 久久久婷 | 一区二区精品在线 | 亚洲 欧美日韩 国产 中文 | 91视频免费看网站 | 天天爱综合 | 天天爽天天做 | 国产中文视 | 亚洲精品国精品久久99热 | 在线观看色网 | 国产视频黄 | 99视屏| 国产91精品高清一区二区三区 | 3d黄动漫免费看 | 97理论电影 | 成人av一区二区在线观看 | 亚洲精品日韩在线观看 | 欧美日韩高清一区二区 | 在线观看视频免费播放 | 99精品欧美一区二区蜜桃免费 | 五月婷久久 | 日韩精品久久久久久久电影竹菊 | 国产99免费| 中文字幕在线免费观看视频 | 天天插一插 | 成人超碰在线 | 亚洲三级毛片 | 国产第一页精品 | 亚洲成a人片在线观看网站口工 | 欧美日韩国产一区二区在线观看 | 天堂av免费在线 | 99电影| 欧美久久久 | 国产精品九九九九九 | 国产精品中文久久久久久久 | 国产精品精 | 麻豆超碰| 超碰成人av | 成人免费电影 | 激情五月六月婷婷 | 久久久久欧美精品999 | 人人添人人 | 一区二区精 | av一区在线| 操老逼免费视频 | 免费三级大片 | 在线激情电影 | 在线观看91精品国产网站 | 天天躁天天狠天天透 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 97电影网手机版 | 激情大尺度视频 | av 一区 二区 久久 | 欧洲一区精品 | 国产手机精品视频 | 高清久久久 | 超碰在线最新网址 | 亚洲精品乱码久久久久久久久久 | 91黄色影视| 亚洲黄色激情小说 | 国内外成人免费在线视频 | 免费观看成年人视频 | 欧美片一区二区三区 | 免费看黄色大全 | 国产高清无av久久 | 久久久久久久久久久影视 | 在线免费高清一区二区三区 | 色国产视频 | 丝袜美女在线 | 成人av一二三区 | 国产精品123| 亚洲区另类春色综合小说校园片 | 99热精品在线观看 | 日韩高清在线一区二区三区 | 国内揄拍国产精品 | 国产精品国产毛片 | 色网站在线免费观看 | 国产免费观看视频 | 丁香国产视频 | 国产精品免费久久久久久久久久中文 | 狠狠色丁香婷婷综合最新地址 | 精品婷婷 | 久保带人 | 国产精品爽爽久久久久久蜜臀 | 免费裸体视频网 | 奇米网网址 | 一二三精品视频 | 蜜臀久久99静品久久久久久 | 久久综合偷偷噜噜噜色 | 日韩中文字幕视频在线 | 国产五月色婷婷六月丁香视频 | 精品免费久久久久 | 欧美日韩一区三区 | 中国老女人日b | 99久久精品免费看 | 深夜免费福利网站 | 伊人五月天.com | 婷婷激情综合 | 中文在线字幕免 | 乱男乱女www7788 | 国产高清视频 | 久久久久免费电影 | 欧美一性一交一乱 | 奇米影视四色8888 | 亚洲午夜在线视频 | 久人人 | 久久av网址| 伊人狠狠干 | 亚洲高清国产视频 | 精品中文字幕视频 | 丁香婷婷色综合亚洲电影 | 成人免费在线网 | 成人蜜桃网 | 狠狠做深爱婷婷综合一区 | 成人免费中文字幕 | 久久精品视频中文字幕 | 热久久国产精品 | 欧美日韩91 | av成人免费观看 | 97视频久久久 | 亚洲精品在线一区二区 | 国产精品综合久久久 | 国产精品视频免费 | 天天干,天天干 | 亚洲成a人片77777kkkk1在线观看 | 免费观看国产精品视频 | 久草热视频| 国产黄色精品在线观看 | 国产999| 免费看一级特黄a大片 | 久久草草热国产精品直播 | 97人人模人人爽人人喊中文字 | 一区二区三区视频网站 | 精品国产99| 成 人 黄 色 视频 免费观看 | 91中文字幕在线观看 | 精品国产区 | 国产一区免费视频 | 日韩在线精品视频 | 欧美人zozo | 国产四虎影院 | 欧美91精品久久久久国产性生爱 | 免费在线色 | 国产成人三级在线 | 999久久精品| 中文资源在线播放 | 在线精品观看 | 欧美日韩在线视频观看 | 国产123区在线观看 国产精品麻豆91 | 欧美色操| 色婷婷激情电影 | 蜜臀av一区二区 | 成片免费观看视频大全 | 成人黄色在线播放 | 国产精品色 | 成人av片免费看 | 国产亚洲欧美精品久久久久久 | 欧洲精品久久久久毛片完整版 | 91精品久久久久久久91蜜桃 | 亚洲精品国产精品国自产 | 91九色性视频 | 久久99视频免费观看 | 在线观看完整版免费 | 欧美激情一区不卡 | 午夜丰满寂寞少妇精品 | 97超碰资源网 | 蜜臀精品久久久久久蜜臀 | 少妇bbb | 国产在线不卡一区 | 91视频电影 | 久久综合国产伦精品免费 | 久久久99精品免费观看乱色 | 麻豆高清免费国产一区 | 久久精品一二三 | 丝袜美女视频网站 | 丰满少妇对白在线偷拍 | 亚洲精品国偷拍自产在线观看 | 成年人在线免费看片 | 成年人免费在线播放 | 天天射天天爱天天干 | 国产1级毛片 | 亚洲粉嫩av| 国产婷婷vvvv激情久 | 成人黄视频 | 人人舔人人爱 | 色综合久久综合中文综合网 | 91一区在线观看 | 亚洲精品在线观看免费 | 国产香蕉久久 | av中文天堂在线 | 国产自产在线视频 | 日韩欧美视频在线观看免费 | av免费高清观看 | 中文在线字幕免 | 国产精品一区欧美 | 97国产超碰在线 | 日韩av电影中文字幕 | 免费高清在线观看成人 | 波多野结衣视频一区二区 | 91专区在线观看 | 在线观看精品国产 | 91丨精品丨蝌蚪丨白丝jk | 中文字幕电影一区 | 免费男女网站 | 日韩大片在线播放 | 成人在线电影观看 | av在线免费网站 | 波多野结衣电影一区二区三区 | 亚洲高清久久久 | 日韩欧美一区二区不卡 | 亚洲免费小视频 | 天天操天天干天天 | 国产精品国产三级国产不产一地 | 午夜精品一区二区国产 | 91最新网址| 国内精品久久久久久久影视麻豆 | 操久久免费视频 | 国产一级黄色片免费看 | 亚洲日本三级 | 欧美一二三视频 | 久久9视频 | 天天艹天天爽 | 91av精品 | 久久精彩 | 99精品视频免费全部在线 | 国产精品影音先锋 | 色婷婷骚婷婷 | 9999精品免费视频 | 91成人看片 | 欧美成人一区二区 | 国产亚洲久一区二区 | 久久只精品99品免费久23小说 | 999久久久免费精品国产 | 国产精品99久久久久的智能播放 | 91大神精品视频在线观看 | 二区三区在线观看 | 国产精品久久久久久久久久久不卡 | 色婷婷久久久综合中文字幕 | 九九视频精品免费 | 天天亚洲| 丁香久久久 | 日日干,天天干 | 欧美精品在线观看一区 | 99久久精品免费看国产免费软件 | 日韩啪啪小视频 | 日韩电影在线观看一区 | 天天综合五月天 | 99视频在线精品 | 欧美在线一级片 | 久久视频在线 | 波多野结衣电影一区二区三区 | 伊人婷婷激情 | 99综合电影在线视频 | 麻花豆传媒mv在线观看 | 国产精品一区二区在线免费观看 | 美女网站视频免费黄 | 精品国产诱惑 | 97理论片 | 亚洲精品视频在线看 | 九九在线视频免费观看 | 在线一区av | 丁香六月婷婷开心婷婷网 | 在线a视频 | 精品一区二区三区久久久 | 九九视频在线观看视频6 | 97在线观视频免费观看 | 麻豆系列在线观看 | 激情中文在线 | 久久久久伦理电影 | 欧美日本不卡 | 免费欧美精品 | 手机成人av| 欧美一级片 | 精品在线观看视频 | 99久久日韩精品免费热麻豆美女 | 免费 在线 中文 日本 | 国产高清久久久久 | av高清不卡| 91看片在线观看 | 国产又粗又猛又爽又黄的视频免费 | 日韩精品电影在线播放 | 亚洲国产一区在线观看 | 国产美女精品久久久 | 91大神精品视频在线观看 | 免费观看福利视频 | 色欧美综合| 国产成人久久久77777 | 欧美性生活大片 | 亚洲一区 av | 日韩在线观看免费 | 中文字幕一区二区三区四区在线视频 | 国产黄色av影视 | 欧美性脚交 | 激情欧美xxxx | 日韩色综合网 | 六月激情丁香 | 日韩在线视 | 五月综合色婷婷 | 欧美人zozo | 日韩视频在线观看免费 | 日本黄色免费在线 | 日韩一区二区三区高清免费看看 | 免费午夜视频在线观看 | 国产亚洲久一区二区 | 免费a v观看 | 日本久久精品 | 在线小视频你懂得 | 久草免费在线视频观看 | 国产精品久久久久久久久久直播 | 在线视频区 | a级片韩国 | 国产99久久久精品 | 深爱开心激情网 | 久久艹综合 | 国产啊v在线 | 最近的中文字幕大全免费版 | 久久尤物电影视频在线观看 | 精品久久久久久久久久 | 国产一区 在线播放 | 五月婷婷中文网 | 久久精品精品电影网 | 91看片成人 | www亚洲一区| 精品福利在线观看 | 国内久久精品 | 99久热在线精品视频观看 | 999精品视频| 五月婷婷开心中文字幕 | 日韩视频在线观看免费 | 国产原创在线视频 | 天躁狠狠躁 | 久久精品欧美视频 | 国产麻豆精品一区二区 | 国产高清绿奴videos | 国产精品白浆视频 | 人人插人人做 | 亚洲色图 校园春色 | 国产成人久 | 欧美日韩视频在线一区 | 亚洲 av网站 | av电影免费在线看 | 国产中文字幕在线免费观看 | 国产伦精品一区二区三区… | 麻花豆传媒mv在线观看 | 国产黄大片在线观看 | 日韩精品网址 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 亚洲第一区在线观看 | 国产 日韩 在线 亚洲 字幕 中文 | 911久久| 九九视频在线观看视频6 | 久久99久久99精品免视看婷婷 | 中文字幕在线观看三区 | 六月丁香在线观看 | 亚洲国产中文在线观看 | 国产午夜精品理论片在线 | 国内精品久久久久久久久久久 | 91视频a | 天天色天天射天天干 | 国产在线播放观看 | 中文字幕在线观看一区二区 | 九九天堂| 天天干天天想 | av高清在线 | 349k.cc看片app | 成年人天堂com| 亚洲精品久久在线 | 久久久久亚洲精品成人网小说 | 国产玖玖在线 | 精品视频一区在线 | 欧美一级片在线观看视频 | 久草资源在线观看 | www.久久色.com| www.亚洲精品在线 | 亚洲黄色片 | 日韩欧美电影网 | 久久久麻豆精品一区二区 | 五月激情丁香图片 | 在线探花 | 天天干天天操天天入 | 久久久久久黄色 | 中文字幕 二区 | 伊人色**天天综合婷婷 | 日韩中字在线观看 | 午夜婷婷网 | 日韩性网站| 国产一级高清 | 中文字幕乱码亚洲精品一区 | 日韩欧美一区二区三区黑寡妇 | 91人网站| 婷婷丁香色 | 黄色国产成人 | 国产精品电影一区 | 亚洲区视频在线观看 | 日韩精品免费在线播放 | 欧美日韩视频一区二区三区 | 欧美日韩一区二区视频在线观看 | 欧美国产大片 | 色偷偷88888欧美精品久久久 | 果冻av在线 | 丁香婷婷综合五月 | 欧美在线视频第一页 | 久久短视频 | 中文字幕 91 | 中文字幕一区二区三区四区 | 午夜国产福利在线 | 中文字幕在线观看三区 | 一区二区三区高清在线观看 | 国产精品美女久久久久久久久久久 | 在线观看视频在线 | 久射网| 欧美日韩在线观看不卡 | 偷拍精偷拍精品欧洲亚洲网站 | 伊香蕉大综综综合久久啪 | 三级动态视频在线观看 | 亚洲精品在线一区二区 | 中文国产成人精品久久一 | 四虎在线观看 | 国产高清在线观看 | 欧美亚洲精品在线观看 | 免费在线黄色av | 久久艹久久 | 国产精选视频 | 国产免费观看高清完整版 | 在线成人小视频 | 91资源在线播放 | 国产99精品 | 免费看的黄色网 | 日日夜夜91 | 一色av| 欧美日本三级 | 在线视频成人 | 久久久免费av | 人人澡人摸人人添学生av | 日韩欧美在线视频一区二区三区 | 香蕉视频最新网址 | 一级片免费在线 | 国产精品成人久久久 | 97超碰在线免费 | 免费三级av | 精品国产区在线 | 国产在线观看xxx | 日韩在线精品一区 | 片网址 | 国产精品va在线观看入 | 久久久久久久久久久免费av | 在线中文字幕av观看 | 日本精品视频在线观看 | 狠狠亚洲| 精品v亚洲v欧美v高清v | 亚洲一级黄色av | 中文字幕在线播放第一页 | 久久久午夜电影 | 欧美一级片免费观看 | 日韩综合第一页 | 国内精品久久久久久久久久清纯 | 亚洲国产精品va在线看黑人 | 国产精品久久精品 | 91丨九色丨高潮 | 四虎成人精品 | 日韩欧美综合精品 | 亚洲精品欧美视频 | 一级片视频在线 | 欧美日韩一区二区在线观看 | 国产香蕉久久精品综合网 | 在线观看中文av | 国产又粗又猛又色又黄网站 | 五月激情五月激情 | 人人爽人人搞 | 国产欧美最新羞羞视频在线观看 | 欧美一级性视频 | av亚洲产国偷v产偷v自拍小说 | 久久免费黄色大片 | 国产成人精品国内自产拍免费看 | 国产精品成人久久久久久久 | 精品极品在线 | 国产韩国日本高清视频 | 91精品国产综合久久福利不卡 | 天天干天天操天天干 | 亚洲午夜久久久久久久久久久 | 久久综合网色—综合色88 | 久久久久久久久久久久久国产精品 | 中文字幕在线播放日韩 | 超碰国产在线观看 | 亚洲三级黄 | 久久免费在线视频 | 这里有精品在线视频 | 久久久久亚洲精品成人网小说 |