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

歡迎訪問 生活随笔!

生活随笔

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

Android

Android插件化原理解析——ContentProvider的插件化

發布時間:2025/3/15 Android 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Android插件化原理解析——ContentProvider的插件化 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

目前為止我們已經完成了Android四大組件中Activity,Service以及BroadcastReceiver的插件化,這幾個組件各不相同,我們根據它們的特點定制了不同的插件化方案;那么對于ContentProvider,它又有什么特點?應該如何實現它的插件化?

與Activity,BroadcastReceiver等頻繁被使用的組件不同,我們接觸和使用ContentProvider的機會要少得多;但是,ContentProvider這個組件對于Android系統有著特別重要的作用——作為一種極其方便的數據共享的手段,ContentProvider使得廣大第三方App能夠在壁壘森嚴的系統中自由呼吸。

在Android系統中,每一個應用程序都有自己的用戶ID,而每一個應用程序所創建的文件的讀寫權限都是只賦予給自己所屬的用戶,這就限制了應用程序之間相互讀寫數據的操作。應用程序之間如果希望能夠進行交互,只能采取跨進程通信的方式;Binder機制能夠滿足一般的IPC需求,但是如果應用程序之間需要共享大量數據,單純使用Binder是很難辦到的——我相信大家對于Binder 1M緩沖區以及TransactionTooLargeException一定不陌生;ContentProvider使用了匿名共享內存(Ashmem)機制完成數據共享,因此它可以很方便地完成大量數據的傳輸。Android系統的短信,聯系人,相冊,媒體庫等等一系列的基礎功能都依賴與ContentProvider,它的重要性可見一斑。

既然ContentProvider的核心特性是數據共享,那么要實現它的插件化,必須能讓插件能夠把它的ContentProvider共享給系統——如果不能「provide content」那還叫什么ContentProvider?

但是,如果回想一下Activity等組件的插件化方式,在涉及到「共享」這個問題上,一直沒有較好的解決方案:

  • 系統中的第三方App無法啟動插件中帶有特定IntentFilter的Activity,因為系統壓根兒感受不到插件中這個真正的Activity的存在。
  • 插件中的靜態注冊的廣播并不真正是靜態的,而是使用動態注冊廣播模擬實現的;這就導致如果宿主程序進程死亡,這個靜態廣播不會起作用;這個問題的根本原因在由于BroadcastReceiver的IntentFilter的不可預知性,使得我們沒有辦法把靜態廣播真正“共享”給系統。
  • 我們沒有辦法在第三方App中啟動或者綁定插件中的Service組件;因為插件的Service并不是真正的Service組件,系統能感知到的只是那個代理Service;因此如果插件如果帶有遠程Service組件,它根本不能給第三方App提供遠程服務。
  • 雖然在插件系統中一派生機勃勃的景象,Activity,Service等插件組件百花齊放,插件與宿主、插件與插件爭奇斗艷;但是一旦脫離了插件系統的溫室,這一片和諧景象不復存在:插件組件不過是傀儡而已;活著的,只有宿主——整個插件系統就是一座死寂的鬼城,各個插件組件借尸還魂般地依附在宿主身上,了無生機。

    既然希望把插件的ContentProvider共享給整個系統,讓第三方的App都能獲取到我們插件共享的數據,我們必須解決這個問題;下文將會圍繞這個目標展開,完成ContentProvider的插件化,并且順帶給出上述問題的解決方案。閱讀本文之前,可以先clone一份?understand-plugin-framework,參考此項目的 contentprovider-management 模塊。另外,插件框架原理解析系列文章見?索引。

    ContentProvider工作原理

    首先我們還是得分析一下ContentProvider的工作原理,很多插件化的思路,以及一些Hook點的發現都嚴重依賴于對于系統工作原理的理解;對于ContentProvider的插件化,這一點特別重要。

    鋪墊工作

    如同我們通過startActivity來啟動Activity一樣,與ContentProvider打交道的過程也是從Context類的一個方法開始的,這個方法叫做getContentResolver,使用ContentProvider的典型代碼如下:

    1 2 ContentResolver resolver = content.getContentResolver(); resolver.query(Uri.parse("content://authority/test"), null, null, null, null);

    直接去ContextImpl類里面查找的getContentResolver實現,發現這個方法返回的類型是android.app.ContextImpl.ApplicationContentResolver,這個類是抽象類android.content.ContentResolver的子類,resolver.query實際上是調用父類ContentResolver的query實現:

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 public final @Nullable Cursor query(final @NonNull Uri uri, @Nullable String[] projection, @Nullable String selection, @Nullable String[] selectionArgs, @Nullable String sortOrder, @Nullable CancellationSignal cancellationSignal) { Preconditions.checkNotNull(uri, "uri"); IContentProvider unstableProvider = acquireUnstableProvider(uri); if (unstableProvider == null) { return null; } IContentProvider stableProvider = null; Cursor qCursor = null; try { long startTime = SystemClock.uptimeMillis(); ICancellationSignal remoteCancellationSignal = null; if (cancellationSignal != null) { cancellationSignal.throwIfCanceled(); remoteCancellationSignal = unstableProvider.createCancellationSignal(); cancellationSignal.setRemote(remoteCancellationSignal); } try { qCursor = unstableProvider.query(mPackageName, uri, projection, selection, selectionArgs, sortOrder, remoteCancellationSignal); } catch (DeadObjectException e) { // The remote process has died... but we only hold an unstable // reference though, so we might recover!!! Let's try!!!! // This is exciting!!1!!1!!!!1 unstableProviderDied(unstableProvider); stableProvider = acquireProvider(uri); if (stableProvider == null) { return null; } qCursor = stableProvider.query(mPackageName, uri, projection, selection, selectionArgs, sortOrder, remoteCancellationSignal); } // 略... }

    注意這里面的那個try..catch語句,query方法首先嘗試調用抽象方法acquireUnstableProvider拿到一個IContentProvider對象,并嘗試調用這個”unstable”對象的query方法,萬一調用失敗(拋出DeadObjectExceptopn,熟悉Binder的應該了解這個異常)說明ContentProvider所在的進程已經死亡,這時候會嘗試調用acquireProvider這個抽象方法來獲取一個可用的IContentProvider(代碼里面那個萌萌的注釋說明了一切^_^);由于這兩個acquire*都是抽象方法,我們可以直接看子類ApplicationContentResolver的實現:

    1 2 3 4 5 6 7 8 9 10 11 12 @Override protected IContentProvider acquireUnstableProvider(Context c, String auth) { return mMainThread.acquireProvider(c, ContentProvider.getAuthorityWithoutUserId(auth), resolveUserIdFromAuthority(auth), false); } @Override protected IContentProvider acquireProvider(Context context, String auth) { return mMainThread.acquireProvider(context, ContentProvider.getAuthorityWithoutUserId(auth), resolveUserIdFromAuthority(auth), true); }

    可以看到這兩個抽象方法最終都通過調用ActivityThread類的acquireProvider獲取到IContentProvider,接下來我們看看到底是如何獲取到ContentProvider的。

    ContentProvider獲取過程

    ActivityThread類的acquireProvider方法如下,我們需要知道的是,方法的最后一個參數stable代表著ContentProvider所在的進程是否存活,如果進程已死,可能需要在必要的時候喚起這個進程;

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 public final IContentProvider acquireProvider( Context c, String auth, int userId, boolean stable) { final IContentProvider provider = acquireExistingProvider(c, auth, userId, stable); if (provider != null) { return provider; } IActivityManager.ContentProviderHolder holder = null; try { holder = ActivityManagerNative.getDefault().getContentProvider( getApplicationThread(), auth, userId, stable); } catch (RemoteException ex) { } if (holder == null) { Slog.e(TAG, "Failed to find provider info for " + auth); return null; } holder = installProvider(c, holder, holder.info, true /*noisy*/, holder.noReleaseNeeded, stable); return holder.provider; }

    這個方法首先通過acquireExistingProvider嘗試從本進程中獲取ContentProvider,如果獲取不到,那么再請求AMS獲取對應ContentProvider;想象一下,如果你查詢的是自己App內部的ContentProvider組件,干嘛要勞煩AMS呢?不論是從哪里獲取到的ContentProvider,獲取完畢之后會調用installProvider來安裝ContentProvider。

    OK打住,我們思考一下,如果要實現ContentProvider的插件化,我們需要完成一些什么工作?開篇的時候我提到了數據共享,那么具體來說,實現插件的數據共享,需要完成什么?ContentProvider是一個數據共享組件,也就是說它不過是一個攜帶數據的載體而已。為了支持跨進程共享,這個載體是Binder調用,為了共享大量數據,使用了匿名共享內存;這么說還是有點抽象,那么想一下,給出一個ContentProvider,你能對它做一些什么操作?如果能讓插件支持這些操作,不就支持了插件化么?這就是典型的duck type思想——如果一個東西看起來像ContentProvider,用起來也像ContentProvider,那么它就是ContentProvider。

    ContentProvider主要支持query, insert, update, delete操作,由于這個組件一般工作在別的進程,因此這些調用都是Binder調用。從上面的代碼可以看到,這些調用最終都是委托給一個IContentProvider的Binder對象完成的,如果我們Hook掉這個對象,那么對于ContentProvider的所有操作都會被我們攔截掉,這時候我們可以做進一步的操作來完成對于插件ContentProvider組件的支持。要攔截這個過程,我們可以假裝插件的ContentProvider是自己App的ContentProvider,也就是說,讓acquireExistingProvider方法可以直接獲取到插件的ContentProvider,這樣我們就不需要欺騙AMS就能完成插件化了。當然,你也可以選擇Hook掉AMS,讓AMS的getContentProvider方法返回被我們處理過的對象,這也是可行的;但是,為什么要舍近求遠呢?

    從上文的分析暫時得出結論:我們可以把插件的ContentProvider信息預先放在App進程內部,使得對于ContentProvider執行CURD操作的時候,可以獲取到插件的組件,這樣或許就可以實現插件化了。具體來說,我們要做的事情就是讓ActivityThread的acquireExistingProvider方法能夠返回插件的ContentProvider信息,我們看看這個方法的實現:

    1 2 3 4 5 6 7 8 9 10 11 12 public final IContentProvider acquireExistingProvider( Context c, String auth, int userId, boolean stable) { synchronized (mProviderMap) { final ProviderKey key = new ProviderKey(auth, userId); final ProviderClientRecord pr = mProviderMap.get(key); if (pr == null) { return null; } // 略。。 } }

    可以看出,App內部自己的ContentProvider信息保存在ActivityThread類的mProviderMap中,這個map的類型是ArrayMap;我們當然可以通過反射修改這個成員變量,直接把插件的ContentProvider信息填進去,但是這個ProviderClientRecord對象如何構造?我們姑且看看系統自己是如果填充這個字段的。在ActivityThread類中搜索一遍,發現調用mProviderMap對象的put方法的之后installProviderAuthoritiesLocked,而這個方法最終被installProvider方法調用。在分析ContentProvider的獲取過程中我們已經知道,不論是通過本進程的acquireExistingProvider還是借助AMS的getContentProvider得到ContentProvider,最終都會對這個對象執行installProvider操作,也就是「安裝」在本進程內部。那么,我們接著看這個installProvider做了什么,它是如何「安裝」ContentProvider的。

    進程內部ContentProvider安裝過程

    首先,如果之前沒有“安裝”過,那么holder為null,下面的代碼會被執行,

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 final java.lang.ClassLoader cl = c.getClassLoader(); localProvider = (ContentProvider)cl. loadClass(info.name).newInstance(); provider = localProvider.getIContentProvider(); if (provider == null) { Slog.e(TAG, "Failed to instantiate class " + info.name + " from sourceDir " + info.applicationInfo.sourceDir); return null; } if (DEBUG_PROVIDER) Slog.v( TAG, "Instantiating local provider " + info.name); // XXX Need to create the correct context for this provider. localProvider.attachInfo(c, info);

    比較直觀,直接load這個ContentProvider所在的類,然后用反射創建出這個ContentProvider對象;但是由于查詢是需要進行跨進程通信的,在本進程創建出這個對象意義不大,所以我們需要取出ContentProvider承載跨進程通信的Binder對象IContentProvider;創建出對象之后,接下來就是構建合適的信息,保存在ActivityThread內部,也就是mProviderMap:

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 if (localProvider != null) { ComponentName cname = new ComponentName(info.packageName, info.name); ProviderClientRecord pr = mLocalProvidersByName.get(cname); if (pr != null) { if (DEBUG_PROVIDER) { Slog.v(TAG, "installProvider: lost the race, " + "using existing local provider"); } provider = pr.mProvider; } else { holder = new IActivityManager.ContentProviderHolder(info); holder.provider = provider; holder.noReleaseNeeded = true; pr = installProviderAuthoritiesLocked(provider, localProvider, holder); mLocalProviders.put(jBinder, pr); mLocalProvidersByName.put(cname, pr); } retHolder = pr.mHolder; } else {

    以上就是安裝代碼,不難理解。

    思路嘗試——本地安裝

    那么,了解了「安裝」過程再結合上文的分析,我們似乎可以完成ContentProvider的插件化了——直接把插件的ContentProvider安裝在進程內部就行了。如果插件系統有多個進程,那么必須在每個進程都「安裝」一遍,如果你熟悉Android進程的啟動流程那么就會知道,這個安裝ContentProvider的過程適合放在Application類中,因為每個Android進程啟動的時候,App的Application類是會被啟動的。

    看起來實現ContentProvider的思路有了,但是這里實際上有一個嚴重的缺陷!

    我們依然沒有解決「共享」的問題。我們只是在插件系統啟動的進程里面的ActivityThread的mProviderMap給修改了,這使得只有通過插件系統啟動的進程,才能感知到插件中的ContentProvider(因為我們手動把插件中的信息install到這個進程中去了);如果第三方的App想要使用插件的ContentProvider,那系統只會告訴它查無此人。

    那么,我們應該如何解決共享這個問題呢?看來還是逃不過AMS的魔掌,我們繼續跟蹤源碼,看看如果在本進程查詢不到ContentProvider,AMS是如何完成這個過程的。在ActivityThread的acquireProvider方法中我們提到,如果acquireExistingProvider方法返回null,會調用ActivityManagerNative的getContentProvider方法通過AMS查詢整個系統中是否存在需要的這個ContentProvider。如果第三方App查詢插件系統的ContentProvider必然走的是這個流程,我們仔細分析一下這個過程;

    AMS中的ContentProvider

    首先我們查閱ActivityManagerService的getContentProvider方法,這個方法間接調用了getContentProviderImpl方法;getContentProviderImpl方法體相當的長,但是實際上只做了兩件事件事(我這就不貼代碼了,讀者可以對著源碼看一遍):

  • 使用PackageManagerService的resolveContentProvider根據Uri中提供的auth信息查閱對應的ContentProivoder的信息ProviderInfo。
  • 根據查詢到的ContentProvider信息,嘗試將這個ContentProvider組件安裝到系統上。
  • 查詢ContentProvider組件的過程

    查詢ContentProvider組件的過程看起來很簡單,直接調用PackageManager的resolveContentProvider就能從URI中獲取到對應的ProviderInfo信息:

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 @Override public ProviderInfo resolveContentProvider(String name, int flags, int userId) { if (!sUserManager.exists(userId)) return null; // reader synchronized (mPackages) { final PackageParser.Provider provider = mProvidersByAuthority.get(name); PackageSetting ps = provider != null ? mSettings.mPackages.get(provider.owner.packageName) : null; return ps != null && mSettings.isEnabledLPr(provider.info, flags, userId) && (!mSafeMode || (provider.info.applicationInfo.flags &ApplicationInfo.FLAG_SYSTEM) != 0) ? PackageParser.generateProviderInfo(provider, flags, ps.readUserState(userId), userId) : null; } }

    但是實際上我們關心的是,這個mProvidersByAuthority里面的信息是如何添加進PackageManagerService的,會在什么時候更新?在PackageManagerService這個類中搜索mProvidersByAuthority.put這個調用,會發現在scanPackageDirtyLI會更新mProvidersByAuthority這個map的信息,接著往前追蹤會發現:這些信息是在Android系統啟動的時候收集的。也就是說,Android系統在啟動的時候會掃描一些App的安裝目錄,典型的比如/data/app/*,獲取這個目錄里面的apk文件,讀取其AndroidManifest.xml中的信息,然后把這些信息保存在PackageManagerService中。合理猜測,在系統啟動之后,安裝新的App也會觸發對新App中AndroidManifest.xml的操作,感興趣的讀者可以自行翻閱源碼。

    現在我們知道,查詢ContentProvider的信息來源在Android系統啟動的時候已經初始化好了,這個過程對于我們第三方app來說是鞭長莫及,想要使用類似在進程內部Hack ContentProvider的查找過程是不可能的。

    安裝ContentProvider組件的過程

    獲取到URI對應的ContentProvider的信息之后,接下來就是把它安裝到系統上了,這樣以后有別的查詢操作就可以直接拿來使用;但是這個安裝過程AMS是沒有辦法以一己之力完成的。想象一下App DemoA 查詢App DemoB 的某個ContentProviderAppB,那么這個ContentProviderAppB必然存在于DemoB這個App中,AMS所在的進程(system_server)連這個ContentProviderAppB的類都沒有,因此,AMS必須委托DemoB完成它的ContentProviderAppB的安裝;這里就分兩種情況:其一,DemoB這個App已經在運行了,那么AMS直接通知DemoB安裝ContentProviderAppB(如果B已經安裝了那就更好了);其二,DemoB這個app沒在運行,那么必須把B進程喚醒,讓它干活;這個過程也就是ActivityManagerService的getContentProviderImpl方法所做的,如下代碼:

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 if (proc != null && proc.thread != null) { if (!proc.pubProviders.containsKey(cpi.name)) { proc.pubProviders.put(cpi.name, cpr); try { proc.thread.scheduleInstallProvider(cpi); } catch (RemoteException e) { } } } else { proc = startProcessLocked(cpi.processName, cpr.appInfo, false, 0, "content provider", new ComponentName(cpi.applicationInfo.packageName, cpi.name), false, false, false); if (proc == null) { return null; } }

    如果查詢的ContentProvider所在進程處于運行狀態,那么AMS會通過這個進程給AMS的ApplicationThread這個Binder對象完成scheduleInstallProvider調用,這個過程比較簡單,最終會調用到目標進程的installProvider方法,而這個方法我們在上文已經分析過了。我們看一下如果目標進程沒有啟動,會發生什么情況。

    如果ContentProvider所在的進程已經死亡,那么會調用startProcessLocked來啟動新的進程,startProcessLocked有一系列重載函數,我們一路跟蹤,發現最終啟動進程的操作交給了Process類的start方法完成,這個方法通過socket與Zygote進程進行通信,通知Zygote進程fork出一個子進程,然后通過反射調用了之前傳遞過來的一個入口類的main函數,一般來說這個入口類就是ActivityThread,因此子進程fork出來之后會執行ActivityThread類的main函數。

    在我們繼續觀察子進程ActivityThread的main函數執行之前,我們看看AMS進程這時候會干什么——startProcessLocked之后AMS進程和fork出來的DemoB進程分道揚鑣;AMS會繼續往下面執行。我們暫時回到AMS的getContentProviderImpl方法:

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 // Wait for the provider to be published... synchronized (cpr) { while (cpr.provider == null) { if (cpr.launchingApp == null) { return null; } try { if (conn != null) { conn.waiting = true; } cpr.wait(); } catch (InterruptedException ex) { } finally { if (conn != null) { conn.waiting = false; } } } }

    你沒看錯,一個死循環就是糊在上面:AMS進程會通過一個死循環等到進程B完成ContentProvider的安裝,等待完成之后會把ContentProvider的信息返回給進程A。那么,我們現在的疑惑是,進程B在啟動之后,在哪個時間點會完成ContentProvider的安裝呢?

    我們接著看ActivityThread的main函數,順便尋找我們上面那個問題的答案;這個分析實際上就是Android App的啟動過程,更詳細的過程可以參閱老羅的文章?Android應用程序啟動過程源代碼分析,這里只給出簡要調用流程:

    App啟動簡要流程

    最終,DemoB進程啟動之后會執行ActivityThread類的handleBindApplication方法,這個方法相當之長,基本完成了App進程啟動之后所有必要的操作;這里我們只關心ContentProvider相關的初始化操作,代碼如下:

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 // If the app is being launched for full backup or restore, bring it up in // a restricted environment with the base application class. Application app = data.info.makeApplication(data.restrictedBackupMode, null); mInitialApplication = app; // don't bring up providers in restricted mode; they may depend on the // app's custom Application class if (!data.restrictedBackupMode) { List<ProviderInfo> providers = data.providers; if (providers != null) { installContentProviders(app, providers); // For process that contains content providers, we want to // ensure that the JIT is enabled "at some point". mH.sendEmptyMessageDelayed(H.ENABLE_JIT, 10*1000); } } // Do this after providers, since instrumentation tests generally start their // test thread at this point, and we don't want that racing. try { mInstrumentation.onCreate(data.instrumentationArgs); } catch (Exception e) { } try { mInstrumentation.callApplicationOnCreate(app); } catch (Exception e) { }

    仔細觀察以上代碼,你會發現:ContentProvider的安裝比Application的onCreate回調還要早!!因此,分析到這里我們已經明白了前面提出的那個問題,進程啟動之后會在Applition類的onCreate 回調之前,在Application對象創建之后完成ContentProvider的安裝

    然后不要忘了,我們的AMS進程還在那傻傻等待DemoB進程完成ContentProviderAppB的安裝呢!在DemoB的Application的onCreate回調之前,DemoB的ContentProviderAppB已經安裝好了,因此AMS停止等待,把DemoB安裝的結果返回給請求這個ContentProvider的DemoA。我們必須對這個時序保持敏感,有時候就是失之毫厘,差之千里!!

    到這里,有關ContentProvider的調用過程以及簡要的工作原理我們已經分析完畢,關于它如何共享數據,如何使用匿名共享內存這部分不是插件化的重點,感興趣的可以參考?Android應用程序組件Content Provider在應用程序之間共享數據的原理分析。

    不同之處

    在實現ContentProvider的插件化之前,通過分析這個組件的工作原理,我們可以得出它的一些與眾不同的特性:

  • ContentProvider本身是用來共享數據的,因此它提供一般的CURD服務;它類似HTTP這種無狀態的服務,沒有Activity,Service所謂的生命周期的概念,服務要么可用,要么不可用;對應著ContentProvider要么啟動,要么隨著進程死亡;而通常情況下,死亡之后還會被系統啟動。所以,ContentProvider,只要有人需要這個服務,系統可以保證是永生的;這是與其他組件的最大不同;完全不用考慮生命周期的概念。
  • ContentProvider被設計為共享數據,這種數據量一般來說是相當大的;熟悉Binder的人應該知道,Binder進行數據傳輸有1M限制,因此如果要使用Binder傳輸大數據,必須使用類似socket的方式一段一段的讀,也就是說需要自己在上層架設一層協議;ContentProvider并沒有采取這種方式,而是采用了Android系統的匿名共享內存機制,利用Binder來傳輸這個文件描述符,進而實現文件的共享;這是第二個不同,因為其他的三個組建通信都是基于Binder的,只有ContentProvider使用了Ashmem。
  • 一個App啟動過程中,ContentProvider組件的啟動是非常早的,甚至比Application的onCreate還要早;我們可以利用這個特性結合它不死的特點,完成一些有意義的事情。
  • ContentProvider存在優先查詢本進程的特點,使得它的插件化甚至不需要Hook AMS就能完成。
  • 思路分析

    在分析ContentProvider的工作原理的過程中我們提出了一種插件化方案:在進程啟動之初,手動把ContentProvider安裝到本進程,使得后續對于插件ContentProvider的請求能夠順利完成。我們也指出它的一個嚴重缺陷,那就是它只能在插件系統內部掩耳盜鈴,在插件系統之外,第三方App依然無法感知到插件中的ContentProvider的存在。

    如果插件的ContentProvider組件僅僅是為了共享給其他插件或者宿主程序使用,那么這種方案可以解決問題;不需要Hook AMS,非常簡單。

    但是,如果希望把插件ContenProvider共享給整個系統呢?在分析AMS中獲取ContentProvider的過程中我們了解到,ContentProvider信息的注冊是在Android系統啟動或者新安裝App的時候完成的,而AMS把ContentProvider返回給第三方App也是在system_server進程完成;我們無法對其暗箱操作。

    在完成Activity,Service組件的插件化之后,這種限制對我們來說已經是小case了:我們在宿主程序里面注冊一個貨真價實、被系統認可的StubContentProvider組件,把這個組件共享給第三方App;然后通過代理分發技術把第三方App對于插件ContentProvider的請求通過這個StubContentProvider分發給對應的插件。

    但是這還存在一個問題,由于第三方App查閱的其實是StubContentProvider,因此他們查閱的URI也必然是StubContentProvider的authority,要查詢到插件的ContentProvider,必須把要查詢的真正的插件ContentProvider信息傳遞進來。這個問題的解決方案也很容易,我們可以制定一個「插件查詢協議」來實現。

    舉個例子,假設插件系統的宿主程序在AndroidManifest.xml中注冊了一個StubContentProvider,它的Authority為com.test.host_authority;由于這個組件被注冊在AndroidManifest.xml中,是系統認可的ContentProvider組件,整個系統都是可以使用這個共享組件的,使用它的URI一般為content://com.test.host_authority;那么,如果插件系統中存在一個插件,這個插件提供了一個PluginContentProvider,它的Authority為com.test.plugin_authorith,因為這個插件的PluginContentProvider沒有在宿主程序的AndroidMainifest.xml中注冊(預先注冊就失去插件的意義了),整個系統是無法感知到它的存在的;前面提到代理分發技術,也就是,我們讓第三方App請求宿主程序的StubContentProvider,這個StubContentProvider把請求轉發給合適的插件的ContentProvider就能完成了(插件內部通過預先installProvider可以查詢所有的ContentProvider組件);這個協議可以有很多,比如說:如果第三方App需要請求插件的StubContentProvider,可以以content://com.test.host_authority/com.test.plugin_authorith去查詢系統;也就是說,我們假裝請求StubContentProvider,把真正的需要請求的PluginContentProvider的Authority放在路徑參數里面,StubContentProvider收到這個請求之后,拿到這個真正的Authority去請求插件的PluginContentProvider,拿到結果之后再返回給第三方App。

    這樣,我們通過「代理分發技術」以及「插件查詢協議」可以完美解決「共享」的問題,開篇提到了我們之前對于Activity,Service組件插件化方案中對于「共享」功能的缺失,按照這個思路,基本可以解決這一系列問題。比如,對于第三方App無法綁定插件服務的問題,我們可以注冊一個StubService,把真正需要bind的插件服務信息放在intent的某個字段中,然后在StubService的onBind中解析出這個插件服務信息,然后去拿到插件Service組件的Binder對象返回給第三方。

    實現

    上文詳細分析了如何實現ContentProvider的插件化,接下來我們就實現這個過程。

    預先installProvider

    要實現預先installProvider,我們首先需要知道,所謂的「預先」到底是在什么時候?

    前文我們提到過App進程安裝ContentProvider的時機非常之早,在Application類的onCreate回調執行之前已經完成了;這意味著什么?

    現在我們對于ContentProvider插件化的實現方式是通過「代理分發技術」,也就是說在請求插件ContentProvider的時候會先請求宿主程序的StubContentProvider;如果一個第三方App查詢插件的ContentProvider,而宿主程序沒有啟動的話,AMS會啟動宿主程序并等待宿主程序的StubContentProvider完成安裝,一旦安裝完成就會把得到的IContentProvider返回給這個第三方App;第三方App拿到IContentProvider這個Binder對象之后就可能發起CURD操作,如果這個時候插件ContentProvider還沒有啟動,那么肯定就會出異常;要記住,“這個時候”可能宿主程序的onCreate還沒有執行完畢呢!!

    所以,我們基本可以得出結論,預先安裝這個所謂的「預先」必須早于Application的onCreate方法,在Android SDK給我們的回調里面,attachBaseContent這個方法是可以滿足要求的,它在Application這個對象被創建之后就會立即調用。

    解決了時機問題,那么我們接下來就可以安裝ContentProvider了。

    安裝ContentProvider也就是要調用ActivityThread類的installProvider方法,這個方法需要的參數有點多,而且它的第二個參數IActivityManager.ContentProviderHolder是一個隱藏類,我們不知道如何構造,就算通過反射構造由于SDK沒有暴露穩定性不易保證,我們看看有什么方法調用了這個installProvider。

    installContentProviders這個方法直接調用installProvder看起來可以使用,但是它是一個private的方法,還有public的方法嗎?繼續往上尋找調用鏈,發現了installSystemProviders這個方法:

    1 2 3 4 5 public final void installSystemProviders(List<ProviderInfo> providers) { if (providers != null) { installContentProviders(mInitialApplication, providers); } }

    但是,我們說過ContentProvider的安裝必須相當早,必須在Application類的attachBaseContent方法內,而這個mInitialApplication字段是在onCreate方法調用之后初始化的,所以,如果直接使用這個installSystemProviders勢必拋出空指針異常;因此,我們只有退而求其次,選擇通過installContentProviders這個方法完成ContentProvider的安裝

    要調用這個方法必須拿到ContentProvider對應的ProviderInfo,這個我們在之前也介紹過,可以通過PackageParser類完成,當然這個類有一些兼容性問題,我們需要手動處理:

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 /** * 解析Apk文件中的 <provider>, 并存儲起來 * 主要是調用PackageParser類的generateProviderInfo方法 * * @param apkFile 插件對應的apk文件 * @throws Exception 解析出錯或者反射調用出錯, 均會拋出異常 */ public static List<ProviderInfo> parseProviders(File apkFile) throws Exception { Class<?> packageParserClass = Class.forName("android.content.pm.PackageParser"); Method parsePackageMethod = packageParserClass.getDeclaredMethod("parsePackage", File.class, int.class); Object packageParser = packageParserClass.newInstance(); // 首先調用parsePackage獲取到apk對象對應的Package對象 Object packageObj = parsePackageMethod.invoke(packageParser, apkFile, PackageManager.GET_PROVIDERS); // 讀取Package對象里面的services字段 // 接下來要做的就是根據這個List<Provider> 獲取到Provider對應的ProviderInfo Field providersField = packageObj.getClass().getDeclaredField("providers"); List providers = (List) providersField.get(packageObj); // 調用generateProviderInfo 方法, 把PackageParser.Provider轉換成ProviderInfo Class<?> packageParser$ProviderClass = Class.forName("android.content.pm.PackageParser$Provider"); Class<?> packageUserStateClass = Class.forName("android.content.pm.PackageUserState"); Class<?> userHandler = Class.forName("android.os.UserHandle"); Method getCallingUserIdMethod = userHandler.getDeclaredMethod("getCallingUserId"); int userId = (Integer) getCallingUserIdMethod.invoke(null); Object defaultUserState = packageUserStateClass.newInstance(); // 需要調用 android.content.pm.PackageParser#generateProviderInfo Method generateProviderInfo = packageParserClass.getDeclaredMethod("generateProviderInfo", packageParser$ProviderClass, int.class, packageUserStateClass, int.class); List<ProviderInfo> ret = new ArrayList<>(); // 解析出intent對應的Provider組件 for (Object service : providers) { ProviderInfo info = (ProviderInfo) generateProviderInfo.invoke(packageParser, service, 0, defaultUserState, userId); ret.add(info); } return ret; }

    解析出ProviderInfo之后,就可以直接調用installContentProvider了:

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 /** * 在進程內部安裝provider, 也就是調用 ActivityThread.installContentProviders方法 * * @param context you know * @param apkFile * @throws Exception */ public static void installProviders(Context context, File apkFile) throws Exception { List<ProviderInfo> providerInfos = parseProviders(apkFile); for (ProviderInfo providerInfo : providerInfos) { providerInfo.applicationInfo.packageName = context.getPackageName(); } Log.d("test", providerInfos.toString()); Class<?> activityThreadClass = Class.forName("android.app.ActivityThread"); Method currentActivityThreadMethod = activityThreadClass.getDeclaredMethod("currentActivityThread"); Object currentActivityThread = currentActivityThreadMethod.invoke(null); Method installProvidersMethod = activityThreadClass.getDeclaredMethod("installContentProviders", Context.class, List.class); installProvidersMethod.setAccessible(true); installProvidersMethod.invoke(currentActivityThread, context, providerInfos); }

    整個安裝過程必須在Application類的attachBaseContent里面完成

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 /** * 一定需要Application,并且在attachBaseContext里面Hook * 因為provider的初始化非常早,比Application的onCreate還要早 * 在別的地方hook都晚了。 * * @author weishu * @date 16/3/29 */ public class UPFApplication extends Application { @Override protected void attachBaseContext(Context base) { super.attachBaseContext(base); try { File apkFile = getFileStreamPath("testcontentprovider-debug.apk"); if (!apkFile.exists()) { Utils.extractAssets(base, "testcontentprovider-debug.apk"); } File odexFile = getFileStreamPath("test.odex"); // Hook ClassLoader, 讓插件中的類能夠被成功加載 BaseDexClassLoaderHookHelper.patchClassLoader(getClassLoader(), apkFile, odexFile); ProviderHelper.installProviders(base, getFileStreamPath("testcontentprovider-debug.apk")); } catch (Exception e) { throw new RuntimeException("hook failed", e); } } }

    代理分發以及協議解析

    把插件中的ContentProvider安裝到插件系統中之后,在插件內部就可以自由使用這些ContentProvider了;要把這些插件共享給整個系統,我們還需要一個貨真價實的ContentProvider組件來執行分發:

    1 2 3 4 5 <provider android:name="com.example.weishu.contentprovider_management.StubContentProvider" android:authorities="com.example.weishu.contentprovider_management.StubContentProvider" android:process=":p" android:exported="true" />

    第三方App如果要查詢到插件的ContentProvider,必須遵循一個「插件查詢協議」,這樣StubContentProvider才能把對于插件的請求分發到正確的插件組件:

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 /** * 為了使得插件的ContentProvder提供給外部使用,我們需要一個StubProvider做中轉; * 如果外部程序需要使用插件系統中插件的ContentProvider,不能直接查詢原來的那個uri * 我們對uri做一些手腳,使得插件系統能識別這個uri; * * 這里的處理方式如下: * * 原始查詢插件的URI應該為: * content://plugin_auth/path/query * * 如果需要查詢插件,需要修改為: * * content://stub_auth/plugin_auth/path/query * * 也就是,我們把插件ContentProvider的信息放在URI的path中保存起來; * 然后在StubProvider中做分發。 * * 當然,也可以使用QueryParamerter,比如: * content://plugin_auth/path/query/ -> content://stub_auth/path/query?plugin=plugin_auth * @param raw 外部查詢我們使用的URI * @return 插件真正的URI */ private Uri getRealUri(Uri raw) { String rawAuth = raw.getAuthority(); if (!AUTHORITY.equals(rawAuth)) { Log.w(TAG, "rawAuth:" + rawAuth); } String uriString = raw.toString(); uriString = uriString.replaceAll(rawAuth + '/', ""); Uri newUri = Uri.parse(uriString); Log.i(TAG, "realUri:" + newUri); return newUri; }

    通過以上過程我們就實現了ContentProvider的插件化。需要說明的是,DroidPlugind的插件化與上述介紹的方案有一些不同之處:

  • 首先DroidPlugin并沒有選擇預先安裝的方案,而是選擇Hook ActivityManagerNative,攔截它的getContentProvider以及publishContentProvider方法實現對于插件組件的控制;從這里可以看出它對ContentProvider與Service的插件化幾乎是相同的,Hook才是DroidPlugin Style ^_^.
  • 然后,關于攜帶插件信息,或者說「插件查詢協議」方面;DroidPlugin把插件信息放在查詢參數里面,本文呢則是路徑參數;這一點完全看個人喜好。
  • 小結

    本文我們通過「代理分發技術」以及「插件查詢協議」完成了ContentProvider組件的插件化,并且給出了對「插件共享組件」的問題的一般解決方案。值得一提的是,系統的ContentProvider其實是lazy load的,也就是說只有在需要使用的時候才會啟動對應的ContentProvider,而我們對于插件的實現則是預先加載,這里還有改進的空間,讀者可以思考一下解決方案。

    由于ContentProvider的使用頻度非常低,而很多它使用的場景(比如系統)并不太需要「插件化」,因此在實際的插件方案中,提供ContentProvider插件化的方案非常之少;就算需要實現ContentProvider的插件化,也只是解決插件內部之間共享組件的問題,并沒有把插件組件暴露給整個系統。我個人覺得,如果只是希望插件化,那么是否支持ContentProvider無傷大雅,但是,如果希望實現虛擬化或者說容器技術,所有組件是必須支持插件化的。

    至此,對于Android系統的四大組件的插件化已經全部介紹完畢;由于是最后一個要介紹的組件,我并沒有像之前一樣先給出組件的運行原理,然后一通分析最后給出插件方案,而是一邊分析代碼一邊給出自己的思路,把思考——推翻——改進的整個過程完全展現了出來,Android的插件化已經到達了百花齊放的階段,插件化之路也不只有一條,但是萬變不離其宗,希望我的分析和思考對各位讀者理解甚至創造插件化方案帶來幫助。接下來我會介紹「插件通信機制」,它與本文的ContentProvider以及我反復強調過的一些特性密切相關,敬請期待!

    原文出處: http://weishu.me/2016/07/12/understand-plugin-framework-content-provider/

    總結

    以上是生活随笔為你收集整理的Android插件化原理解析——ContentProvider的插件化的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    中文精品久久久久人妻不卡 | 欧美成人午夜精品久久久 | 大胆欧美熟妇xx | 国产成人一区二区三区别 | 亚洲熟妇色xxxxx欧美老妇y | 人妻互换免费中文字幕 | 欧美人与禽zoz0性伦交 | 天天做天天爱天天爽综合网 | 欧美xxxx黑人又粗又长 | 99精品国产综合久久久久五月天 | 亚洲一区二区三区无码久久 | 精品夜夜澡人妻无码av蜜桃 | 色窝窝无码一区二区三区色欲 | 狠狠色噜噜狠狠狠狠7777米奇 | 捆绑白丝粉色jk震动捧喷白浆 | 中文字幕无码人妻少妇免费 | 欧美精品无码一区二区三区 | 麻豆国产人妻欲求不满 | 亚洲一区二区三区国产精华液 | 嫩b人妻精品一区二区三区 | 一本久久a久久精品亚洲 | 娇妻被黑人粗大高潮白浆 | 99久久人妻精品免费一区 | 最新国产乱人伦偷精品免费网站 | 成人精品天堂一区二区三区 | 国产 精品 自在自线 | 5858s亚洲色大成网站www | 亚洲色偷偷男人的天堂 | 精品一二三区久久aaa片 | 熟妇人妻无乱码中文字幕 | 日本熟妇浓毛 | 亚洲一区二区三区四区 | 无遮无挡爽爽免费视频 | 国产无遮挡又黄又爽又色 | 久久久国产一区二区三区 | 日本www一道久久久免费榴莲 | 国产精品99久久精品爆乳 | 天天躁夜夜躁狠狠是什么心态 | 色综合久久久无码中文字幕 | 玩弄中年熟妇正在播放 | 亚洲а∨天堂久久精品2021 | 欧美熟妇另类久久久久久多毛 | 久久精品国产一区二区三区 | 强开小婷嫩苞又嫩又紧视频 | 欧洲美熟女乱又伦 | 国产婷婷色一区二区三区在线 | 国产欧美亚洲精品a | 亚洲精品综合一区二区三区在线 | 亚洲精品欧美二区三区中文字幕 | 中文精品无码中文字幕无码专区 | 在线天堂新版最新版在线8 | 永久免费观看美女裸体的网站 | 99久久久无码国产aaa精品 | 99精品国产综合久久久久五月天 | 成年美女黄网站色大免费视频 | 国产精品久久久av久久久 | 纯爱无遮挡h肉动漫在线播放 | 国产乡下妇女做爰 | 在教室伦流澡到高潮hnp视频 | 久久精品国产一区二区三区肥胖 | 久久久婷婷五月亚洲97号色 | 久久久久亚洲精品中文字幕 | 全球成人中文在线 | 欧美国产亚洲日韩在线二区 | 亚洲乱码国产乱码精品精 | 国产另类ts人妖一区二区 | 久久精品人妻少妇一区二区三区 | 国产超级va在线观看视频 | 熟妇人妻无码xxx视频 | 未满成年国产在线观看 | 一本大道久久东京热无码av | 少女韩国电视剧在线观看完整 | 天天摸天天透天天添 | 一本加勒比波多野结衣 | 国产激情精品一区二区三区 | 国产成人综合在线女婷五月99播放 | 精品国产麻豆免费人成网站 | 天天爽夜夜爽夜夜爽 | 亚洲午夜福利在线观看 | 天天拍夜夜添久久精品 | 国产无遮挡又黄又爽免费视频 | 国产亚洲精品久久久久久久久动漫 | 久久亚洲精品成人无码 | 欧美喷潮久久久xxxxx | 成人精品视频一区二区 | 人妻尝试又大又粗久久 | 亚洲精品综合一区二区三区在线 | 日本一卡2卡3卡四卡精品网站 | 国产激情综合五月久久 | 啦啦啦www在线观看免费视频 | 女人被男人躁得好爽免费视频 | 亚洲va中文字幕无码久久不卡 | 熟妇女人妻丰满少妇中文字幕 | 国产明星裸体无码xxxx视频 | 男人扒开女人内裤强吻桶进去 | 四虎永久在线精品免费网址 | 亚洲国产精品一区二区美利坚 | 日本精品少妇一区二区三区 | 巨爆乳无码视频在线观看 | 奇米影视7777久久精品人人爽 | 国产真实乱对白精彩久久 | 最近中文2019字幕第二页 | 久久精品中文字幕一区 | 精品无码成人片一区二区98 | 在线精品国产一区二区三区 | 伊人久久婷婷五月综合97色 | 无码纯肉视频在线观看 | 偷窥日本少妇撒尿chinese | 人妻中文无码久热丝袜 | 亚洲乱亚洲乱妇50p | 国产成人av免费观看 | 国产精品自产拍在线观看 | 日韩av无码一区二区三区 | 黑森林福利视频导航 | 日本熟妇浓毛 | 久久国产自偷自偷免费一区调 | 亚洲精品国产精品乱码视色 | 精品午夜福利在线观看 | 国产成人无码av在线影院 | 欧美人与善在线com | 日韩人妻无码一区二区三区久久99 | 疯狂三人交性欧美 | 综合网日日天干夜夜久久 | 日韩在线不卡免费视频一区 | 牲欲强的熟妇农村老妇女 | 亚洲色欲色欲天天天www | 色窝窝无码一区二区三区色欲 | 成年女人永久免费看片 | 亚洲国产精品成人久久蜜臀 | 国产成人久久精品流白浆 | 亚洲欧洲日本无在线码 | 黑人粗大猛烈进出高潮视频 | 亚洲欧美日韩成人高清在线一区 | 麻花豆传媒剧国产免费mv在线 | 国产午夜精品一区二区三区嫩草 | 又色又爽又黄的美女裸体网站 | 日本一区二区更新不卡 | 97久久国产亚洲精品超碰热 | 午夜男女很黄的视频 | 久久久精品456亚洲影院 | 熟妇女人妻丰满少妇中文字幕 | a国产一区二区免费入口 | 免费无码的av片在线观看 | 无套内射视频囯产 | 97久久国产亚洲精品超碰热 | 少妇一晚三次一区二区三区 | 天堂亚洲2017在线观看 | 中文久久乱码一区二区 | 无码午夜成人1000部免费视频 | 色五月丁香五月综合五月 | 疯狂三人交性欧美 | 奇米影视888欧美在线观看 | 国产无av码在线观看 | 成人无码精品1区2区3区免费看 | 乱码av麻豆丝袜熟女系列 | 中国女人内谢69xxxxxa片 | 搡女人真爽免费视频大全 | 国产热a欧美热a在线视频 | 乱人伦人妻中文字幕无码 | 亚洲熟女一区二区三区 | 国产精品美女久久久久av爽李琼 | 曰韩无码二三区中文字幕 | 青青久在线视频免费观看 | 亚洲 另类 在线 欧美 制服 | 99久久精品午夜一区二区 | 无码人妻av免费一区二区三区 | 亚洲熟妇色xxxxx欧美老妇y | 国产精品久久精品三级 | 日本一卡2卡3卡四卡精品网站 | 成人免费视频在线观看 | 国产特级毛片aaaaaaa高清 | 日本乱人伦片中文三区 | 少妇性俱乐部纵欲狂欢电影 | 中文字幕无线码免费人妻 | 老头边吃奶边弄进去呻吟 | 久久久精品人妻久久影视 | 国产熟妇高潮叫床视频播放 | 国产艳妇av在线观看果冻传媒 | 国产一区二区三区四区五区加勒比 | √天堂资源地址中文在线 | 黑人巨大精品欧美一区二区 | 亚洲一区二区三区在线观看网站 | 国产偷自视频区视频 | 日韩亚洲欧美中文高清在线 | 亚洲午夜福利在线观看 | 久久久久免费看成人影片 | 色狠狠av一区二区三区 | 一个人看的视频www在线 | 蜜桃臀无码内射一区二区三区 | 亚洲爆乳大丰满无码专区 | 精品久久久中文字幕人妻 | 国内精品九九久久久精品 | 99久久精品午夜一区二区 | 2019nv天堂香蕉在线观看 | 日本护士毛茸茸高潮 | 欧美日韩在线亚洲综合国产人 | 强伦人妻一区二区三区视频18 | 又湿又紧又大又爽a视频国产 | 国产精品免费大片 | 国产国产精品人在线视 | 精品 日韩 国产 欧美 视频 | 99久久无码一区人妻 | 性欧美疯狂xxxxbbbb | 免费播放一区二区三区 | 亚洲成a人一区二区三区 | 人人妻人人澡人人爽欧美精品 | 76少妇精品导航 | 三级4级全黄60分钟 | 狂野欧美性猛xxxx乱大交 | 久久国产精品二国产精品 | 亚洲成色www久久网站 | 欧美自拍另类欧美综合图片区 | 中文字幕 人妻熟女 | 国产亲子乱弄免费视频 | 亚洲成av人在线观看网址 | yw尤物av无码国产在线观看 | 国产偷抇久久精品a片69 | 亚洲国产精品久久久久久 | 成在人线av无码免观看麻豆 | 男女作爱免费网站 | 亚洲天堂2017无码 | 免费国产成人高清在线观看网站 | 无套内射视频囯产 | 亚洲精品午夜无码电影网 | 国产sm调教视频在线观看 | 国产精品久久久久影院嫩草 | 久久亚洲中文字幕精品一区 | 色欲综合久久中文字幕网 | 日本护士xxxxhd少妇 | 欧美日韩在线亚洲综合国产人 | 男女性色大片免费网站 | 双乳奶水饱满少妇呻吟 | 野狼第一精品社区 | 日本xxxx色视频在线观看免费 | 真人与拘做受免费视频一 | 亚洲gv猛男gv无码男同 | 免费观看又污又黄的网站 | 久久人人爽人人爽人人片av高清 | 日本丰满护士爆乳xxxx | 大肉大捧一进一出好爽视频 | 亚洲七七久久桃花影院 | 亚洲啪av永久无码精品放毛片 | 色综合久久久久综合一本到桃花网 | 精品国产一区二区三区av 性色 | 中文字幕av伊人av无码av | 午夜精品一区二区三区在线观看 | 久久精品国产一区二区三区肥胖 | 香蕉久久久久久av成人 | 婷婷五月综合激情中文字幕 | 国产另类ts人妖一区二区 | 300部国产真实乱 | 一本大道伊人av久久综合 | 性欧美大战久久久久久久 | 宝宝好涨水快流出来免费视频 | 黑人大群体交免费视频 | 久久视频在线观看精品 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 自拍偷自拍亚洲精品被多人伦好爽 | a国产一区二区免费入口 | 偷窥日本少妇撒尿chinese | 亚洲综合无码一区二区三区 | 国产成人精品视频ⅴa片软件竹菊 | 国产av一区二区三区最新精品 | 久在线观看福利视频 | 欧美35页视频在线观看 | 精品无人区无码乱码毛片国产 | 奇米影视7777久久精品人人爽 | 亚洲人亚洲人成电影网站色 | 老司机亚洲精品影院 | 岛国片人妻三上悠亚 | 色一情一乱一伦一区二区三欧美 | 国产精品igao视频网 | 欧美性色19p | 国产av无码专区亚洲awww | √天堂资源地址中文在线 | 中文字幕无码免费久久99 | 亚洲精品久久久久久一区二区 | 久久精品国产大片免费观看 | 国产精品igao视频网 | 中文无码伦av中文字幕 | 久久亚洲国产成人精品性色 | 黄网在线观看免费网站 | 成人av无码一区二区三区 | 牲欲强的熟妇农村老妇女视频 | 中国女人内谢69xxxxxa片 | 久久精品国产大片免费观看 | 国产偷国产偷精品高清尤物 | 亚洲无人区一区二区三区 | 97久久超碰中文字幕 | 国产真人无遮挡作爱免费视频 | 成人无码视频在线观看网站 | 国产亚洲精品久久久久久国模美 | 亚洲自偷精品视频自拍 | 四虎国产精品免费久久 | 亚洲中文字幕成人无码 | 夜夜影院未满十八勿进 | 亚洲精品成人福利网站 | 亚洲a无码综合a国产av中文 | 精品厕所偷拍各类美女tp嘘嘘 | 国产综合久久久久鬼色 | 欧美人与善在线com | 一个人免费观看的www视频 | 色综合久久中文娱乐网 | 午夜嘿嘿嘿影院 | 老熟女重囗味hdxx69 | 精品欧洲av无码一区二区三区 | 亚洲国产精品久久久久久 | 久久久久av无码免费网 | 妺妺窝人体色www在线小说 | 女高中生第一次破苞av | 成人免费视频视频在线观看 免费 | 国精产品一区二区三区 | 无码国模国产在线观看 | 日日碰狠狠丁香久燥 | 狠狠躁日日躁夜夜躁2020 | 免费无码av一区二区 | 日韩 欧美 动漫 国产 制服 | 天堂а√在线中文在线 | 亚洲人成影院在线观看 | 好爽又高潮了毛片免费下载 | 欧美野外疯狂做受xxxx高潮 | 亚洲精品国产精品乱码视色 | 纯爱无遮挡h肉动漫在线播放 | 国产精品毛多多水多 | 中文无码伦av中文字幕 | 亲嘴扒胸摸屁股激烈网站 | 国产成人一区二区三区别 | 伊人久久大香线蕉av一区二区 | 成人无码精品1区2区3区免费看 | 四虎影视成人永久免费观看视频 | 欧美老妇交乱视频在线观看 | 狂野欧美性猛交免费视频 | 麻豆人妻少妇精品无码专区 | 久久99国产综合精品 | 国产片av国语在线观看 | 女高中生第一次破苞av | 国产亚洲精品精品国产亚洲综合 | 久久精品成人欧美大片 | 欧美自拍另类欧美综合图片区 | 亚洲精品久久久久久久久久久 | 亚洲国产综合无码一区 | 中文字幕日韩精品一区二区三区 | 中文字幕无码av波多野吉衣 | 装睡被陌生人摸出水好爽 | 精品亚洲成av人在线观看 | 黑人巨大精品欧美一区二区 | 日日天日日夜日日摸 | 国产乱人偷精品人妻a片 | 18精品久久久无码午夜福利 | 熟妇女人妻丰满少妇中文字幕 | 亚洲成a人片在线观看日本 | 亚洲色大成网站www国产 | 国产黄在线观看免费观看不卡 | 亚洲啪av永久无码精品放毛片 | 久久精品国产99久久6动漫 | 对白脏话肉麻粗话av | 大乳丰满人妻中文字幕日本 | 在线观看国产午夜福利片 | av无码久久久久不卡免费网站 | 大肉大捧一进一出视频出来呀 | 少妇的肉体aa片免费 | 精品成人av一区二区三区 | 欧美怡红院免费全部视频 | 欧美黑人乱大交 | 国产亚洲精品久久久久久久 | 日韩欧美成人免费观看 | 人妻无码久久精品人妻 | 俺去俺来也在线www色官网 | 精品无人国产偷自产在线 | 久久久久人妻一区精品色欧美 | 又色又爽又黄的美女裸体网站 | 亚洲 激情 小说 另类 欧美 | 99精品无人区乱码1区2区3区 | 久久99国产综合精品 | 高潮毛片无遮挡高清免费视频 | 伊人色综合久久天天小片 | 亚洲色在线无码国产精品不卡 | 亚洲精品国产品国语在线观看 | 久久精品人人做人人综合 | 久在线观看福利视频 | 亚洲无人区午夜福利码高清完整版 | 永久免费精品精品永久-夜色 | 亚洲精品久久久久avwww潮水 | 人妻无码αv中文字幕久久琪琪布 | 亚洲另类伦春色综合小说 | 图片小说视频一区二区 | 国产精品亚洲一区二区三区喷水 | 熟妇人妻无乱码中文字幕 | 国产国语老龄妇女a片 | 国产精品无码永久免费888 | 国产 浪潮av性色四虎 | 国产精品国产自线拍免费软件 | 国产成人精品无码播放 | 国产精品久久福利网站 | 欧美 日韩 亚洲 在线 | 亚洲日本一区二区三区在线 | 久久精品无码一区二区三区 | 久久精品国产99久久6动漫 | 黑人粗大猛烈进出高潮视频 | 亚洲 激情 小说 另类 欧美 | 亚洲熟女一区二区三区 | 日本xxxx色视频在线观看免费 | 久久zyz资源站无码中文动漫 | 午夜丰满少妇性开放视频 | 亚洲狠狠婷婷综合久久 | 熟女少妇在线视频播放 | 色窝窝无码一区二区三区色欲 | 亚洲 欧美 激情 小说 另类 | 伊人久久婷婷五月综合97色 | 成人性做爰aaa片免费看 | 精品无码国产一区二区三区av | 国产又爽又猛又粗的视频a片 | 久久亚洲中文字幕无码 | 中文字幕av无码一区二区三区电影 | 国产香蕉97碰碰久久人人 | 乱中年女人伦av三区 | 欧美三级不卡在线观看 | 无码av最新清无码专区吞精 | 2019午夜福利不卡片在线 | 久久无码专区国产精品s | 色一情一乱一伦一区二区三欧美 | 中文字幕+乱码+中文字幕一区 | 精品国精品国产自在久国产87 | 午夜精品一区二区三区在线观看 | 亚洲欧美色中文字幕在线 | 国产亚洲精品久久久闺蜜 | 性色欲网站人妻丰满中文久久不卡 | 精品一二三区久久aaa片 | 亚洲色成人中文字幕网站 | av无码久久久久不卡免费网站 | 国产精品鲁鲁鲁 | 日本精品久久久久中文字幕 | 亚洲午夜福利在线观看 | 国产手机在线αⅴ片无码观看 | 思思久久99热只有频精品66 | 激情综合激情五月俺也去 | 亚洲大尺度无码无码专区 | 好爽又高潮了毛片免费下载 | 亚洲乱码中文字幕在线 | 亚洲综合无码久久精品综合 | 欧美日本免费一区二区三区 | 久久精品视频在线看15 | 国产成人久久精品流白浆 | 搡女人真爽免费视频大全 | 俺去俺来也www色官网 | 性色欲情网站iwww九文堂 | 亚洲中文无码av永久不收费 | 国产乱人伦av在线无码 | 无码av中文字幕免费放 | 国内精品人妻无码久久久影院 | 日本饥渴人妻欲求不满 | 国产激情无码一区二区 | 人妻少妇精品无码专区动漫 | 日韩精品成人一区二区三区 | 亚洲欧美国产精品久久 | www国产亚洲精品久久久日本 | 日本乱偷人妻中文字幕 | 人妻夜夜爽天天爽三区 | 男女猛烈xx00免费视频试看 | 精品国产一区二区三区av 性色 | 亚洲中文字幕乱码av波多ji | 男女猛烈xx00免费视频试看 | 国产电影无码午夜在线播放 | 国产欧美亚洲精品a | 粉嫩少妇内射浓精videos | 日本欧美一区二区三区乱码 | 欧美xxxxx精品 | 无码人妻出轨黑人中文字幕 | 久久国产精品二国产精品 | 久久久精品成人免费观看 | 伊在人天堂亚洲香蕉精品区 | 中文字幕无码免费久久9一区9 | 大胆欧美熟妇xx | 欧美日韩人成综合在线播放 | 亚洲色成人中文字幕网站 | a片免费视频在线观看 | 丰满少妇人妻久久久久久 | 国产香蕉尹人综合在线观看 | 亚洲欧美国产精品久久 | 免费无码肉片在线观看 | 日韩精品无码免费一区二区三区 | 麻豆av传媒蜜桃天美传媒 | 亚洲 高清 成人 动漫 | 久久人人爽人人爽人人片av高清 | 2019nv天堂香蕉在线观看 | 图片区 小说区 区 亚洲五月 | 99er热精品视频 | 国産精品久久久久久久 | 激情综合激情五月俺也去 | 婷婷色婷婷开心五月四房播播 | 国产精品亚洲专区无码不卡 | 曰韩少妇内射免费播放 | 天天摸天天碰天天添 | 又粗又大又硬又长又爽 | 亚洲精品久久久久avwww潮水 | 欧美三级不卡在线观看 | 六十路熟妇乱子伦 | 中文字幕 人妻熟女 | 国产精品鲁鲁鲁 | 国产内射老熟女aaaa | 成人精品视频一区二区 | 国产精品久久久久久亚洲毛片 | 亚洲s码欧洲m码国产av | 天堂а√在线中文在线 | 巨爆乳无码视频在线观看 | 骚片av蜜桃精品一区 | 欧美35页视频在线观看 | 欧美乱妇无乱码大黄a片 | 久久国语露脸国产精品电影 | 免费播放一区二区三区 | 一二三四在线观看免费视频 | 天堂无码人妻精品一区二区三区 | 国内精品久久毛片一区二区 | 免费无码的av片在线观看 | 亚洲国产精品无码一区二区三区 | 亚洲色成人中文字幕网站 | 在线观看国产午夜福利片 | 九九热爱视频精品 | 国产香蕉尹人综合在线观看 | 亚洲爆乳大丰满无码专区 | 特黄特色大片免费播放器图片 | 色综合天天综合狠狠爱 | 乱人伦中文视频在线观看 | 性欧美疯狂xxxxbbbb | 亚洲日韩精品欧美一区二区 | 无码帝国www无码专区色综合 | 国产综合色产在线精品 | 在线观看欧美一区二区三区 | 亚洲色大成网站www | 久激情内射婷内射蜜桃人妖 | 国产香蕉尹人综合在线观看 | 蜜桃臀无码内射一区二区三区 | 小鲜肉自慰网站xnxx | 中文字幕精品av一区二区五区 | 欧美午夜特黄aaaaaa片 | 国产亚洲欧美日韩亚洲中文色 | 色欲av亚洲一区无码少妇 | 久久久国产精品无码免费专区 | 99久久人妻精品免费一区 | 精品欧洲av无码一区二区三区 | 99精品视频在线观看免费 | 国产乱码精品一品二品 | 天天拍夜夜添久久精品大 | 亚洲国产精品毛片av不卡在线 | 亚洲中文字幕无码中文字在线 | 老司机亚洲精品影院 | 国产莉萝无码av在线播放 | 亚洲另类伦春色综合小说 | 7777奇米四色成人眼影 | 狠狠色欧美亚洲狠狠色www | 久久久精品国产sm最大网站 | 少妇性俱乐部纵欲狂欢电影 | 18无码粉嫩小泬无套在线观看 | 天天躁夜夜躁狠狠是什么心态 | 少妇高潮喷潮久久久影院 | 动漫av网站免费观看 | 俺去俺来也在线www色官网 | 欧美刺激性大交 | 久久国产精品萌白酱免费 | 日产国产精品亚洲系列 | av小次郎收藏 | 国产精品理论片在线观看 | 曰韩无码二三区中文字幕 | 国产精品理论片在线观看 | 色老头在线一区二区三区 | 又粗又大又硬又长又爽 | 伊人久久大香线焦av综合影院 | 日本熟妇人妻xxxxx人hd | 日韩精品一区二区av在线 | 无码一区二区三区在线观看 | 天下第一社区视频www日本 | 内射巨臀欧美在线视频 | 波多野结衣一区二区三区av免费 | 国产又粗又硬又大爽黄老大爷视 | 国产成人无码午夜视频在线观看 | 国产女主播喷水视频在线观看 | 图片小说视频一区二区 | 亚洲春色在线视频 | 欧美日本日韩 | 国产电影无码午夜在线播放 | 男女爱爱好爽视频免费看 | 中文字幕无码热在线视频 | 国产精品久久久久无码av色戒 | 我要看www免费看插插视频 | 99久久精品无码一区二区毛片 | 97人妻精品一区二区三区 | 亚洲中文字幕无码一久久区 | 永久免费精品精品永久-夜色 | 色婷婷香蕉在线一区二区 | 亚洲色偷偷男人的天堂 | 搡女人真爽免费视频大全 | 激情综合激情五月俺也去 | 精品日本一区二区三区在线观看 | 欧美亚洲日韩国产人成在线播放 | 欧美丰满熟妇xxxx性ppx人交 | 日本一卡2卡3卡四卡精品网站 | 日本熟妇浓毛 | 欧美性生交xxxxx久久久 | 67194成是人免费无码 | 国产人妻大战黑人第1集 | 国产精品无码成人午夜电影 | 欧美国产亚洲日韩在线二区 | 网友自拍区视频精品 | 国内精品人妻无码久久久影院 | 波多野结衣av一区二区全免费观看 | 蜜臀aⅴ国产精品久久久国产老师 | 伊人色综合久久天天小片 | 亚洲日韩av一区二区三区四区 | 三级4级全黄60分钟 | 欧美日韩久久久精品a片 | av无码电影一区二区三区 | 免费看男女做好爽好硬视频 | 欧美日韩亚洲国产精品 | 波多野结衣av一区二区全免费观看 | 97久久国产亚洲精品超碰热 | 欧美三级不卡在线观看 | 欧美人与禽zoz0性伦交 | 性色欲情网站iwww九文堂 | 亚洲成熟女人毛毛耸耸多 | 午夜精品一区二区三区在线观看 | 久久国语露脸国产精品电影 | 亚洲精品午夜无码电影网 | 欧美日本精品一区二区三区 | 国产精品igao视频网 | 欧美大屁股xxxxhd黑色 | 少妇无套内谢久久久久 | 久久午夜无码鲁丝片秋霞 | 日本xxxx色视频在线观看免费 | 久激情内射婷内射蜜桃人妖 | 欧洲vodafone精品性 | 麻豆国产人妻欲求不满 | 欧美日韩综合一区二区三区 | 久久99精品久久久久久 | а√资源新版在线天堂 | 九九久久精品国产免费看小说 | 人妻夜夜爽天天爽三区 | 99re在线播放 | 人人澡人人透人人爽 | 伊人久久大香线焦av综合影院 | 国产精品多人p群无码 | 98国产精品综合一区二区三区 | 啦啦啦www在线观看免费视频 | 成人欧美一区二区三区 | 人人爽人人爽人人片av亚洲 | 午夜精品久久久久久久 | 国产精品久久久久久亚洲毛片 | 亚洲精品一区二区三区在线观看 | 久久99国产综合精品 | 午夜性刺激在线视频免费 | √8天堂资源地址中文在线 | 999久久久国产精品消防器材 | 国产精品久久久久久久9999 | 无码人妻黑人中文字幕 | 亚洲一区二区三区含羞草 | 亚洲成av人片在线观看无码不卡 | 中国大陆精品视频xxxx | 午夜精品一区二区三区在线观看 | 日本精品人妻无码免费大全 | aa片在线观看视频在线播放 | 波多野结衣av在线观看 | 在线看片无码永久免费视频 | 黑人粗大猛烈进出高潮视频 | 亚洲精品综合一区二区三区在线 | 乱中年女人伦av三区 | 久精品国产欧美亚洲色aⅴ大片 | 人人妻人人澡人人爽精品欧美 | 亚洲成熟女人毛毛耸耸多 | 在线精品国产一区二区三区 | 午夜福利一区二区三区在线观看 | 久久亚洲国产成人精品性色 | 无码人妻久久一区二区三区不卡 | 99久久亚洲精品无码毛片 | 日本精品人妻无码77777 天堂一区人妻无码 | 精品国精品国产自在久国产87 | 国产激情艳情在线看视频 | 一本久久伊人热热精品中文字幕 | 无码精品国产va在线观看dvd | 国产熟妇另类久久久久 | 欧美日韩在线亚洲综合国产人 | 在线观看国产一区二区三区 | 国产在线aaa片一区二区99 | 黑人玩弄人妻中文在线 | 亚洲va中文字幕无码久久不卡 | 国内精品一区二区三区不卡 | 在线а√天堂中文官网 | 色情久久久av熟女人妻网站 | 国产麻豆精品一区二区三区v视界 | 人人妻人人藻人人爽欧美一区 | 国产乱人无码伦av在线a | 精品少妇爆乳无码av无码专区 | 无码人妻丰满熟妇区毛片18 | 国产极品视觉盛宴 | 欧美高清在线精品一区 | 亚洲国产精品久久久久久 | 国产美女极度色诱视频www | 亚洲男人av香蕉爽爽爽爽 | 国内揄拍国内精品人妻 | 人人爽人人爽人人片av亚洲 | 18精品久久久无码午夜福利 | 曰韩少妇内射免费播放 | 亚洲爆乳无码专区 | 久久99精品久久久久久 | 131美女爱做视频 | 男女性色大片免费网站 | 西西人体www44rt大胆高清 | 少妇太爽了在线观看 | 麻豆国产丝袜白领秘书在线观看 | 久久熟妇人妻午夜寂寞影院 | 无码人妻黑人中文字幕 | 欧美熟妇另类久久久久久不卡 | 狠狠噜狠狠狠狠丁香五月 | 一本无码人妻在中文字幕免费 | 国产av一区二区精品久久凹凸 | 少妇一晚三次一区二区三区 | 成人动漫在线观看 | 99久久精品国产一区二区蜜芽 | 日韩少妇内射免费播放 | 激情内射亚州一区二区三区爱妻 | 久久精品国产99久久6动漫 | 综合网日日天干夜夜久久 | 国产熟妇高潮叫床视频播放 | 国产无遮挡又黄又爽又色 | 牲交欧美兽交欧美 | 久久99精品久久久久久动态图 | 爆乳一区二区三区无码 | 国产内射爽爽大片视频社区在线 | 久久国产精品二国产精品 | 亚洲国产精品毛片av不卡在线 | 国产精品人人爽人人做我的可爱 | 久久久国产一区二区三区 | 爱做久久久久久 | 成人免费无码大片a毛片 | 久久国语露脸国产精品电影 | 奇米影视7777久久精品人人爽 | 久9re热视频这里只有精品 | 亚洲一区二区三区偷拍女厕 | 欧美xxxx黑人又粗又长 | 强奷人妻日本中文字幕 | 九月婷婷人人澡人人添人人爽 | 国产麻豆精品精东影业av网站 | 天天综合网天天综合色 | 蜜桃臀无码内射一区二区三区 | 精品国产一区二区三区四区 | 国产高清不卡无码视频 | 国产亚洲精品久久久久久久久动漫 | av无码不卡在线观看免费 | 中文字幕久久久久人妻 | 377p欧洲日本亚洲大胆 | 久久久久久九九精品久 | 精品国产青草久久久久福利 | 极品嫩模高潮叫床 | 日韩成人一区二区三区在线观看 | a片免费视频在线观看 | 麻豆果冻传媒2021精品传媒一区下载 | 国产网红无码精品视频 | 国产乱人无码伦av在线a | 国精产品一品二品国精品69xx | 国语自产偷拍精品视频偷 | 欧美zoozzooz性欧美 | 日本成熟视频免费视频 | 小泽玛莉亚一区二区视频在线 | 夜先锋av资源网站 | 999久久久国产精品消防器材 | 色综合天天综合狠狠爱 | 99久久人妻精品免费二区 | 色一情一乱一伦一视频免费看 | 强伦人妻一区二区三区视频18 | 久久人人97超碰a片精品 | 亚洲日本一区二区三区在线 | 日本爽爽爽爽爽爽在线观看免 | 午夜性刺激在线视频免费 | 未满成年国产在线观看 | 亚洲色欲色欲天天天www | 久久成人a毛片免费观看网站 | 97se亚洲精品一区 | 又大又硬又爽免费视频 | 蜜桃视频插满18在线观看 | 图片区 小说区 区 亚洲五月 | 丰满妇女强制高潮18xxxx | v一区无码内射国产 | 久久精品国产一区二区三区 | 欧美丰满熟妇xxxx性ppx人交 | 欧美精品无码一区二区三区 | 亚洲a无码综合a国产av中文 | 亚洲精品综合一区二区三区在线 | 97久久超碰中文字幕 | 欧美性生交活xxxxxdddd | 性欧美疯狂xxxxbbbb | 成人无码精品1区2区3区免费看 | 天堂亚洲免费视频 | 无套内谢的新婚少妇国语播放 | 成熟女人特级毛片www免费 | 亚洲一区二区三区四区 | 色综合久久中文娱乐网 | 国产真实乱对白精彩久久 | 欧美丰满熟妇xxxx | 亚洲日韩一区二区三区 | 国产婷婷色一区二区三区在线 | 一本久道高清无码视频 | 成人影院yy111111在线观看 | 精品偷拍一区二区三区在线看 | 麻豆md0077饥渴少妇 | 国产亚av手机在线观看 | 人妻体内射精一区二区三四 | 少妇被粗大的猛进出69影院 | 中文字幕无码av波多野吉衣 | 最近中文2019字幕第二页 | 欧美亚洲日韩国产人成在线播放 | 丰满岳乱妇在线观看中字无码 | 波多野结衣一区二区三区av免费 | 久久aⅴ免费观看 | 亚洲精品中文字幕 | 亚洲欧美日韩国产精品一区二区 | 日本丰满护士爆乳xxxx | 久久国产精品二国产精品 | 亚洲无人区一区二区三区 | 亚洲一区二区三区国产精华液 | 精品欧洲av无码一区二区三区 | 97久久国产亚洲精品超碰热 | 精品久久久中文字幕人妻 | 强奷人妻日本中文字幕 | 无码国模国产在线观看 | 综合网日日天干夜夜久久 | 九九久久精品国产免费看小说 | 亚洲日韩av一区二区三区中文 | 国产乱人伦av在线无码 | 少妇性荡欲午夜性开放视频剧场 | 无码av免费一区二区三区试看 | 国产偷国产偷精品高清尤物 | 精品国产成人一区二区三区 | 色综合久久久久综合一本到桃花网 | 国产色在线 | 国产 | www成人国产高清内射 | 中文字幕中文有码在线 | 玩弄少妇高潮ⅹxxxyw | 国产午夜手机精彩视频 | 久久久www成人免费毛片 | 国内老熟妇对白xxxxhd | 中文精品久久久久人妻不卡 | 国产做国产爱免费视频 | 亚洲人成无码网www | 日本护士xxxxhd少妇 | 国产性生大片免费观看性 | 亚洲娇小与黑人巨大交 | 亚洲成av人片在线观看无码不卡 | 国产办公室秘书无码精品99 | 天天做天天爱天天爽综合网 | 永久免费观看国产裸体美女 | 中文字幕人妻无码一夲道 | 日韩人妻系列无码专区 | 精品国产aⅴ无码一区二区 | 午夜免费福利小电影 | 中文字幕 人妻熟女 | 中文字幕乱码亚洲无线三区 | 日日天干夜夜狠狠爱 | 亚洲国产欧美国产综合一区 | 精品偷拍一区二区三区在线看 | 伊人色综合久久天天小片 | 日本xxxx色视频在线观看免费 | 国产色在线 | 国产 | a国产一区二区免费入口 | 国产偷抇久久精品a片69 | 午夜无码人妻av大片色欲 | 无人区乱码一区二区三区 | www国产亚洲精品久久网站 | 野外少妇愉情中文字幕 | 精品国产福利一区二区 | 55夜色66夜色国产精品视频 | 国产偷抇久久精品a片69 | 国产成人无码a区在线观看视频app | 久久无码中文字幕免费影院蜜桃 | 色一情一乱一伦一区二区三欧美 | 伊在人天堂亚洲香蕉精品区 | 亚洲欧洲日本综合aⅴ在线 | 久久国产精品精品国产色婷婷 | 国产片av国语在线观看 | 日欧一片内射va在线影院 | 日韩精品成人一区二区三区 | 国产精品久久久 | 国产精品久免费的黄网站 | 亚洲日本va中文字幕 | 国产亚洲精品久久久闺蜜 | 国产精品久久久久7777 | aⅴ亚洲 日韩 色 图网站 播放 | 国产成人av免费观看 | 国产欧美精品一区二区三区 | 日韩无码专区 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 成人亚洲精品久久久久软件 | 又黄又爽又色的视频 | 久久久久久久久蜜桃 | 曰本女人与公拘交酡免费视频 | 99精品久久毛片a片 | 人人爽人人澡人人高潮 | 国产精品人人爽人人做我的可爱 | 国产精品沙发午睡系列 | 风流少妇按摩来高潮 | 无遮无挡爽爽免费视频 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 国色天香社区在线视频 | 国产精品理论片在线观看 | 人妻体内射精一区二区三四 | 色欲综合久久中文字幕网 | 亚洲成av人片在线观看无码不卡 | 日日噜噜噜噜夜夜爽亚洲精品 | 久久久久久久人妻无码中文字幕爆 | 国产真实伦对白全集 | 中文字幕 亚洲精品 第1页 | 性欧美疯狂xxxxbbbb | 亚洲无人区午夜福利码高清完整版 | 午夜精品一区二区三区的区别 | 白嫩日本少妇做爰 | 国产莉萝无码av在线播放 | 最近免费中文字幕中文高清百度 | 无码人妻av免费一区二区三区 | 成年美女黄网站色大免费视频 | 国产精品高潮呻吟av久久4虎 | 双乳奶水饱满少妇呻吟 | 国产麻豆精品精东影业av网站 | 无码毛片视频一区二区本码 | 人妻互换免费中文字幕 | 无码一区二区三区在线 | 日本www一道久久久免费榴莲 | 亚洲精品久久久久中文第一幕 | a在线观看免费网站大全 | 国产精品多人p群无码 | 蜜臀av无码人妻精品 | 亚洲自偷自拍另类第1页 | 人人澡人人透人人爽 | 国产九九九九九九九a片 | 漂亮人妻洗澡被公强 日日躁 | 黑人粗大猛烈进出高潮视频 | 国产午夜亚洲精品不卡 | 乱人伦中文视频在线观看 | 无人区乱码一区二区三区 | 又粗又大又硬毛片免费看 | 亚洲国产一区二区三区在线观看 | 99久久婷婷国产综合精品青草免费 | 成人精品视频一区二区三区尤物 | 亚洲男女内射在线播放 | 欧美色就是色 | 自拍偷自拍亚洲精品10p | 欧美日本精品一区二区三区 | 人妻尝试又大又粗久久 | 午夜精品一区二区三区的区别 | 国产精品永久免费视频 | 久久99热只有频精品8 | 中文字幕亚洲情99在线 | 少妇人妻大乳在线视频 | 亚洲天堂2017无码 | 欧美丰满熟妇xxxx | 最近中文2019字幕第二页 | 久久国产自偷自偷免费一区调 | 午夜福利一区二区三区在线观看 | 无码人妻久久一区二区三区不卡 | 日日橹狠狠爱欧美视频 | 亚洲中文无码av永久不收费 | 国产人妻人伦精品 | 亚洲经典千人经典日产 | 亚洲色欲色欲天天天www | 又粗又大又硬毛片免费看 | 国产午夜亚洲精品不卡 | 精品无码一区二区三区爱欲 | 日本大香伊一区二区三区 | 午夜免费福利小电影 | 中文字幕人妻无码一夲道 | 无遮无挡爽爽免费视频 | 漂亮人妻洗澡被公强 日日躁 | 成人三级无码视频在线观看 | 亚洲成色在线综合网站 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 妺妺窝人体色www在线小说 | 夫妻免费无码v看片 | 日韩精品久久久肉伦网站 | 又大又硬又黄的免费视频 | 欧美freesex黑人又粗又大 | 久久久久99精品国产片 | 狠狠噜狠狠狠狠丁香五月 | 欧美老熟妇乱xxxxx | 中文字幕av伊人av无码av | 国产肉丝袜在线观看 | 国模大胆一区二区三区 | 久久人人爽人人爽人人片av高清 | 亚洲综合色区中文字幕 | 好男人www社区 | 久久无码中文字幕免费影院蜜桃 | 夫妻免费无码v看片 | 综合激情五月综合激情五月激情1 | 国内精品人妻无码久久久影院 | 2020最新国产自产精品 | 人人爽人人澡人人高潮 | 色偷偷人人澡人人爽人人模 | 图片区 小说区 区 亚洲五月 | 99视频精品全部免费免费观看 | 国产性生大片免费观看性 | 亚洲精品国偷拍自产在线麻豆 | 18精品久久久无码午夜福利 | 免费观看激色视频网站 | 老太婆性杂交欧美肥老太 | 99麻豆久久久国产精品免费 | 国产精品-区区久久久狼 | 日日麻批免费40分钟无码 | 少妇性l交大片欧洲热妇乱xxx | 亚洲乱码中文字幕在线 | 国产精品高潮呻吟av久久 | 精品一区二区三区无码免费视频 | 女人被男人躁得好爽免费视频 | 免费国产黄网站在线观看 | 成人亚洲精品久久久久软件 | 波多野42部无码喷潮在线 | 久久www免费人成人片 | 精品一区二区三区无码免费视频 | 激情五月综合色婷婷一区二区 | 国产片av国语在线观看 | 国产成人综合色在线观看网站 | 成人精品天堂一区二区三区 | 色一情一乱一伦一区二区三欧美 | 国产激情无码一区二区app | 中文字幕人妻无码一区二区三区 | 欧美人与禽zoz0性伦交 | 综合激情五月综合激情五月激情1 | 兔费看少妇性l交大片免费 | 少妇无套内谢久久久久 | 特大黑人娇小亚洲女 | 在线观看国产一区二区三区 | 国产成人精品一区二区在线小狼 | 欧美人与动性行为视频 | 天天综合网天天综合色 | 天天做天天爱天天爽综合网 | 丰腴饱满的极品熟妇 | 99久久人妻精品免费一区 | 亚洲人成网站免费播放 | 狠狠cao日日穞夜夜穞av | www成人国产高清内射 | 精品国产一区二区三区av 性色 | 人妻少妇精品视频专区 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 人妻人人添人妻人人爱 | 久久综合九色综合欧美狠狠 | 日本熟妇浓毛 | 纯爱无遮挡h肉动漫在线播放 | 在线亚洲高清揄拍自拍一品区 | 麻豆av传媒蜜桃天美传媒 | 极品嫩模高潮叫床 | 亚洲熟熟妇xxxx | 无码人妻黑人中文字幕 | 国产内射老熟女aaaa | 天天av天天av天天透 | 欧美丰满老熟妇xxxxx性 | 国产成人综合色在线观看网站 | 老太婆性杂交欧美肥老太 | 一本久久伊人热热精品中文字幕 | 中文亚洲成a人片在线观看 | 国产偷国产偷精品高清尤物 | 99久久人妻精品免费一区 | 草草网站影院白丝内射 | 天天摸天天透天天添 | 人人爽人人爽人人片av亚洲 | 国产av人人夜夜澡人人爽麻豆 | 人妻aⅴ无码一区二区三区 | 精品厕所偷拍各类美女tp嘘嘘 | 精品人妻中文字幕有码在线 | 国产xxx69麻豆国语对白 | 亚洲娇小与黑人巨大交 | 亚洲 另类 在线 欧美 制服 | 国产av久久久久精东av | 天干天干啦夜天干天2017 | 成人无码视频在线观看网站 | 精品一区二区三区无码免费视频 | 99久久亚洲精品无码毛片 | 亚洲国产精品毛片av不卡在线 | 亚洲中文字幕在线观看 | 国产97色在线 | 免 | 国产激情无码一区二区 | 狠狠色噜噜狠狠狠狠7777米奇 | 一本色道婷婷久久欧美 | 国内揄拍国内精品人妻 | 亚洲色偷偷男人的天堂 | 99久久婷婷国产综合精品青草免费 | 国产乡下妇女做爰 | 国产色视频一区二区三区 | 婷婷六月久久综合丁香 | 无码纯肉视频在线观看 | 久久99精品国产麻豆蜜芽 | 动漫av网站免费观看 | 国产97色在线 | 免 | 亚洲狠狠色丁香婷婷综合 | 中文亚洲成a人片在线观看 | 亚洲国产精品无码一区二区三区 | 亚洲欧洲中文日韩av乱码 | 久久久婷婷五月亚洲97号色 | 久久综合色之久久综合 | 久久精品国产一区二区三区 | 无码国内精品人妻少妇 | 国产成人无码av在线影院 | 中文字幕无码免费久久99 | 亚洲精品国偷拍自产在线麻豆 | 欧美zoozzooz性欧美 | 国产精品丝袜黑色高跟鞋 | 夜夜夜高潮夜夜爽夜夜爰爰 | 欧美精品免费观看二区 | 国精产品一品二品国精品69xx | 又大又黄又粗又爽的免费视频 | 大乳丰满人妻中文字幕日本 | av香港经典三级级 在线 | 国产亚洲人成a在线v网站 | 粉嫩少妇内射浓精videos | 天堂а√在线地址中文在线 | 正在播放老肥熟妇露脸 | 在线а√天堂中文官网 | 波多野结衣av一区二区全免费观看 | 欧美人与善在线com | 亚洲乱码日产精品bd | 亚洲春色在线视频 | 中文字幕+乱码+中文字幕一区 | 美女张开腿让人桶 | av无码电影一区二区三区 | 亚洲日韩中文字幕在线播放 | 精品亚洲韩国一区二区三区 | 国产精品无码mv在线观看 | 久久久久久久久蜜桃 | 又黄又爽又色的视频 | 色偷偷人人澡人人爽人人模 | 国产 浪潮av性色四虎 | 无码人妻av免费一区二区三区 | 任你躁国产自任一区二区三区 | 国产成人精品视频ⅴa片软件竹菊 | 国产欧美熟妇另类久久久 | 亚洲成av人综合在线观看 | 久久综合香蕉国产蜜臀av | 亚洲精品午夜无码电影网 | 亚洲色www成人永久网址 | 黑人巨大精品欧美一区二区 | 人妻少妇精品无码专区二区 | 日韩精品乱码av一区二区 | 牛和人交xxxx欧美 | 又湿又紧又大又爽a视频国产 | 久久亚洲a片com人成 | 精品一区二区三区波多野结衣 | 性色欲情网站iwww九文堂 | 无码国产色欲xxxxx视频 | 熟女少妇人妻中文字幕 | 国内精品人妻无码久久久影院 | 精品久久久无码人妻字幂 | 久久久精品欧美一区二区免费 | 日日摸日日碰夜夜爽av | 麻豆果冻传媒2021精品传媒一区下载 | 精品国产乱码久久久久乱码 | 亚洲最大成人网站 | 人妻少妇被猛烈进入中文字幕 | 乌克兰少妇性做爰 | 中文字幕人妻无码一区二区三区 | 久久www免费人成人片 | 久久综合激激的五月天 | 激情内射亚州一区二区三区爱妻 | 国产成人无码av片在线观看不卡 | 99久久婷婷国产综合精品青草免费 | 中国女人内谢69xxxxxa片 | 中文字幕人妻无码一区二区三区 | 国色天香社区在线视频 | 荫蒂添的好舒服视频囗交 | 国产内射爽爽大片视频社区在线 | 久久久中文字幕日本无吗 | 一个人免费观看的www视频 | 国产亚洲欧美在线专区 | 国产欧美亚洲精品a | 成人综合网亚洲伊人 | 国産精品久久久久久久 | 激情综合激情五月俺也去 | 丰腴饱满的极品熟妇 | 国产精品久久久久久亚洲毛片 | 亚洲高清偷拍一区二区三区 | 九九综合va免费看 | 久久无码中文字幕免费影院蜜桃 | 欧美激情内射喷水高潮 | 亚洲第一无码av无码专区 | 国产另类ts人妖一区二区 | 四虎永久在线精品免费网址 | 亚洲成av人片天堂网无码】 | 中文字幕无码热在线视频 | 欧美一区二区三区 | 国产色xx群视频射精 | 国产成人精品久久亚洲高清不卡 | 久久97精品久久久久久久不卡 | 东京一本一道一二三区 | 欧美 日韩 人妻 高清 中文 | 少妇人妻av毛片在线看 | 中文字幕无码免费久久9一区9 | 我要看www免费看插插视频 | 学生妹亚洲一区二区 | 亚洲人成网站色7799 | 免费国产成人高清在线观看网站 | 日产国产精品亚洲系列 | 丝袜足控一区二区三区 | 欧美真人作爱免费视频 | а√天堂www在线天堂小说 | 夜夜影院未满十八勿进 | 在线精品亚洲一区二区 | 女人被男人躁得好爽免费视频 | 午夜性刺激在线视频免费 | 国产深夜福利视频在线 | 精品成在人线av无码免费看 | 麻豆av传媒蜜桃天美传媒 | 美女毛片一区二区三区四区 | 亚洲春色在线视频 | 狂野欧美性猛xxxx乱大交 | 欧美性猛交内射兽交老熟妇 | 成人亚洲精品久久久久 | 麻豆成人精品国产免费 | 成人免费视频视频在线观看 免费 | 无码国模国产在线观看 | 骚片av蜜桃精品一区 | 久久久精品国产sm最大网站 | 天天av天天av天天透 | 久久午夜夜伦鲁鲁片无码免费 | 国产乡下妇女做爰 | 亚洲精品鲁一鲁一区二区三区 | 国产精品多人p群无码 | 好屌草这里只有精品 | 久久这里只有精品视频9 | 国产精品资源一区二区 | 成人无码精品一区二区三区 | 成人精品天堂一区二区三区 | 成在人线av无码免观看麻豆 | 蜜桃臀无码内射一区二区三区 | 人妻插b视频一区二区三区 | 高中生自慰www网站 | 亚洲精品中文字幕久久久久 | 乌克兰少妇xxxx做受 | 最近的中文字幕在线看视频 | 国产手机在线αⅴ片无码观看 | 国产精品无套呻吟在线 | 牛和人交xxxx欧美 | 一二三四在线观看免费视频 | 性欧美videos高清精品 | 伊人久久大香线蕉av一区二区 | 欧美激情综合亚洲一二区 | 国产猛烈高潮尖叫视频免费 | 国产成人无码午夜视频在线观看 | 天下第一社区视频www日本 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 日日碰狠狠躁久久躁蜜桃 | 国产猛烈高潮尖叫视频免费 | 131美女爱做视频 | 捆绑白丝粉色jk震动捧喷白浆 | 天海翼激烈高潮到腰振不止 | 日本精品少妇一区二区三区 | 无码人妻av免费一区二区三区 | 99国产精品白浆在线观看免费 | 亚洲熟悉妇女xxx妇女av | 亚洲欧美精品aaaaaa片 | 国内综合精品午夜久久资源 | 免费无码一区二区三区蜜桃大 | 三级4级全黄60分钟 | 装睡被陌生人摸出水好爽 | 中文字幕人成乱码熟女app | 亚洲色欲色欲欲www在线 | 色综合久久88色综合天天 | 午夜免费福利小电影 | 色综合天天综合狠狠爱 | 国产农村乱对白刺激视频 | 天下第一社区视频www日本 | 狠狠色欧美亚洲狠狠色www | 亚洲精品午夜国产va久久成人 | 国产亚洲人成a在线v网站 | 婷婷丁香五月天综合东京热 | 狠狠色噜噜狠狠狠狠7777米奇 | 男女下面进入的视频免费午夜 | 久久久精品国产sm最大网站 | 无码国产乱人伦偷精品视频 | 亚洲欧美精品伊人久久 | 乱码午夜-极国产极内射 | 亚洲 欧美 激情 小说 另类 | 久久精品国产精品国产精品污 | 国产真实伦对白全集 | 久久久久亚洲精品中文字幕 | 色妞www精品免费视频 | 久久精品人妻少妇一区二区三区 | 日韩 欧美 动漫 国产 制服 | 中文无码成人免费视频在线观看 | 国产另类ts人妖一区二区 | 国产亚洲精品久久久久久大师 | 国产一区二区不卡老阿姨 | 领导边摸边吃奶边做爽在线观看 | 欧美人与物videos另类 | 亚洲综合无码久久精品综合 | 亚洲精品鲁一鲁一区二区三区 | 亚洲国产综合无码一区 | 中文字幕无码av激情不卡 | aⅴ亚洲 日韩 色 图网站 播放 | 国产艳妇av在线观看果冻传媒 | 成人aaa片一区国产精品 | 极品嫩模高潮叫床 | 欧美性猛交xxxx富婆 | 中文久久乱码一区二区 | 久久人人爽人人爽人人片av高清 | 欧美日韩在线亚洲综合国产人 | 成人片黄网站色大片免费观看 | 日韩少妇内射免费播放 | 澳门永久av免费网站 | 高清国产亚洲精品自在久久 | 无码人妻丰满熟妇区毛片18 | 国产成人无码一二三区视频 | 欧美黑人性暴力猛交喷水 | 欧美阿v高清资源不卡在线播放 | 国产在线无码精品电影网 | 美女扒开屁股让男人桶 | 无套内谢的新婚少妇国语播放 | 成人精品视频一区二区三区尤物 | 人妻无码αv中文字幕久久琪琪布 | 国产黑色丝袜在线播放 | 久久久久国色av免费观看性色 | 国产精品美女久久久 | 激情人妻另类人妻伦 | 国产免费观看黄av片 | 亚洲欧美国产精品久久 | 国产成人无码午夜视频在线观看 | 天天拍夜夜添久久精品大 | 无码人妻丰满熟妇区五十路百度 | 欧美三级不卡在线观看 | 丰满肥臀大屁股熟妇激情视频 | 国产精品无码一区二区三区不卡 | 久久综合激激的五月天 | 两性色午夜视频免费播放 | 成年美女黄网站色大免费视频 | 小泽玛莉亚一区二区视频在线 | 亚洲一区二区三区偷拍女厕 | 国产特级毛片aaaaaaa高清 | 欧美日韩久久久精品a片 | 国产乡下妇女做爰 | 曰韩少妇内射免费播放 | 亚洲精品国产第一综合99久久 | a在线观看免费网站大全 | 激情内射亚州一区二区三区爱妻 | 超碰97人人做人人爱少妇 | 麻豆国产丝袜白领秘书在线观看 | 亚洲自偷精品视频自拍 | 女人被男人爽到呻吟的视频 | 国产成人精品一区二区在线小狼 | 美女毛片一区二区三区四区 | 久久精品国产99精品亚洲 | 国产人妻精品一区二区三区不卡 | 强开小婷嫩苞又嫩又紧视频 | 久久无码中文字幕免费影院蜜桃 | 水蜜桃色314在线观看 | v一区无码内射国产 | 国产两女互慰高潮视频在线观看 | 亚洲精品欧美二区三区中文字幕 | 一本久道久久综合婷婷五月 | 好屌草这里只有精品 | 亚洲国产精品一区二区第一页 | 美女毛片一区二区三区四区 | 麻豆国产人妻欲求不满 | 久久精品中文闷骚内射 | 国产成人av免费观看 | 图片区 小说区 区 亚洲五月 | 国产熟女一区二区三区四区五区 | 亚洲一区二区三区含羞草 | 免费无码一区二区三区蜜桃大 | 久久久无码中文字幕久... | 精品久久久无码中文字幕 | 成人精品视频一区二区 | 亚洲成av人综合在线观看 | 无码人妻丰满熟妇区五十路百度 | 天堂无码人妻精品一区二区三区 | 国产人妻人伦精品1国产丝袜 | 窝窝午夜理论片影院 | 国产精品怡红院永久免费 | 人妻插b视频一区二区三区 | 国产超级va在线观看视频 | 麻豆精品国产精华精华液好用吗 | 国产偷国产偷精品高清尤物 | 99久久人妻精品免费一区 | 久久视频在线观看精品 | 男女下面进入的视频免费午夜 | 日本爽爽爽爽爽爽在线观看免 | 久久国产精品精品国产色婷婷 | 精品无码一区二区三区的天堂 | 日日摸夜夜摸狠狠摸婷婷 | 国产激情艳情在线看视频 | 国内老熟妇对白xxxxhd | 国产手机在线αⅴ片无码观看 | 亚洲七七久久桃花影院 | 伊在人天堂亚洲香蕉精品区 | 18黄暴禁片在线观看 | 三上悠亚人妻中文字幕在线 | 内射后入在线观看一区 | 97色伦图片97综合影院 | 熟妇人妻激情偷爽文 | 亚洲 欧美 激情 小说 另类 | 欧美人与物videos另类 | 亚洲成a人片在线观看日本 | 精品国偷自产在线视频 | 黑人大群体交免费视频 | 又粗又大又硬又长又爽 | 亚洲欧美色中文字幕在线 | 牲欲强的熟妇农村老妇女 | 色欲人妻aaaaaaa无码 | 国产av一区二区精品久久凹凸 | 欧美精品无码一区二区三区 | 色情久久久av熟女人妻网站 | 又粗又大又硬毛片免费看 | 四虎国产精品免费久久 | 天天av天天av天天透 | 中文无码伦av中文字幕 | 国产精品无套呻吟在线 | 久久午夜无码鲁丝片秋霞 | 西西人体www44rt大胆高清 | 亚洲日韩一区二区三区 | 无码av岛国片在线播放 | 国产人成高清在线视频99最全资源 | 欧美变态另类xxxx | 国产97人人超碰caoprom | 久久97精品久久久久久久不卡 | 久久久久国色av免费观看性色 | 国产一区二区三区日韩精品 | 丰满少妇弄高潮了www | 超碰97人人做人人爱少妇 | 丰满人妻被黑人猛烈进入 | 日本乱人伦片中文三区 | 亚洲区小说区激情区图片区 | 亚拍精品一区二区三区探花 | 国产尤物精品视频 | 亚洲国产综合无码一区 | 亚洲人成网站在线播放942 | 国产乱码精品一品二品 | 亚洲欧美色中文字幕在线 | 内射爽无广熟女亚洲 | 成人免费无码大片a毛片 | 中文字幕日产无线码一区 | 日韩欧美中文字幕在线三区 | 天下第一社区视频www日本 | 国产亚洲日韩欧美另类第八页 | 国产人妻久久精品二区三区老狼 | 伊人色综合久久天天小片 | 激情内射日本一区二区三区 | 久久熟妇人妻午夜寂寞影院 | 久久久av男人的天堂 | 正在播放老肥熟妇露脸 | 纯爱无遮挡h肉动漫在线播放 | 亚洲国产精品无码久久久久高潮 | 欧美日韩一区二区综合 | 狠狠色丁香久久婷婷综合五月 | 3d动漫精品啪啪一区二区中 | 牲欲强的熟妇农村老妇女 | 超碰97人人射妻 | 天下第一社区视频www日本 | 国产国产精品人在线视 | 国产精品二区一区二区aⅴ污介绍 | 国产精品毛多多水多 | 国产精品久久久久无码av色戒 | 特大黑人娇小亚洲女 | 欧美乱妇无乱码大黄a片 | 久久精品女人的天堂av | 丝袜足控一区二区三区 | 俺去俺来也在线www色官网 | √8天堂资源地址中文在线 | 55夜色66夜色国产精品视频 | 无码人中文字幕 | 人妻互换免费中文字幕 | 国产精品人人妻人人爽 | 老太婆性杂交欧美肥老太 | 国产精品多人p群无码 | 国内精品九九久久久精品 | 国产精品爱久久久久久久 | 熟妇人妻无码xxx视频 | 国产色xx群视频射精 | 欧美国产日韩久久mv | 狠狠亚洲超碰狼人久久 | 亚洲第一无码av无码专区 | 老司机亚洲精品影院 | 性色欲情网站iwww九文堂 | 啦啦啦www在线观看免费视频 | 欧美日本精品一区二区三区 | 亚洲综合久久一区二区 | 欧美怡红院免费全部视频 | 国产av剧情md精品麻豆 | 亚洲 日韩 欧美 成人 在线观看 | 国产麻豆精品一区二区三区v视界 | 国产黄在线观看免费观看不卡 | 亚洲爆乳大丰满无码专区 | 国产 精品 自在自线 | 在线看片无码永久免费视频 | 牲交欧美兽交欧美 | 少妇被黑人到高潮喷出白浆 | 精品无码一区二区三区爱欲 | 青青草原综合久久大伊人精品 | 欧美 日韩 亚洲 在线 | 国产精品国产三级国产专播 | 成人无码视频免费播放 | 欧美野外疯狂做受xxxx高潮 | 亚洲人成影院在线无码按摩店 | 国产成人精品一区二区在线小狼 | 小泽玛莉亚一区二区视频在线 | 娇妻被黑人粗大高潮白浆 | 人妻无码久久精品人妻 | 国产成人无码av片在线观看不卡 | 天堂久久天堂av色综合 | 欧美性生交xxxxx久久久 | 久久亚洲中文字幕精品一区 | 亚洲va欧美va天堂v国产综合 | 成年女人永久免费看片 | 精品日本一区二区三区在线观看 | 成人无码视频免费播放 | 一二三四在线观看免费视频 | 好爽又高潮了毛片免费下载 | 亚洲自偷精品视频自拍 | 国内老熟妇对白xxxxhd | 狂野欧美性猛xxxx乱大交 | 日日躁夜夜躁狠狠躁 | 粗大的内捧猛烈进出视频 | 最新版天堂资源中文官网 | 国产精品18久久久久久麻辣 | 性欧美大战久久久久久久 | 亚洲欧美精品伊人久久 | 亚洲成a人片在线观看无码 | 欧美自拍另类欧美综合图片区 | 亚洲精品综合一区二区三区在线 | 性色av无码免费一区二区三区 | 天天爽夜夜爽夜夜爽 | 少女韩国电视剧在线观看完整 | 一个人看的www免费视频在线观看 | 欧美野外疯狂做受xxxx高潮 | 国产亚av手机在线观看 | 无套内谢的新婚少妇国语播放 | 国产成人无码一二三区视频 | 国语自产偷拍精品视频偷 | 无人区乱码一区二区三区 | 国产乱人无码伦av在线a | 国产色在线 | 国产 | 大肉大捧一进一出视频出来呀 | 粉嫩少妇内射浓精videos | 300部国产真实乱 | 亚洲国产成人av在线观看 | 亚洲日本在线电影 | 国产精品久久久 | 亚洲男人av天堂午夜在 | 亚洲人交乣女bbw | 欧美高清在线精品一区 | 国产真实伦对白全集 | 日本乱人伦片中文三区 | 真人与拘做受免费视频 | 免费观看又污又黄的网站 | 国产美女极度色诱视频www | 人妻少妇精品视频专区 | 麻豆国产丝袜白领秘书在线观看 | 国产特级毛片aaaaaaa高清 | 亚洲精品一区二区三区在线观看 | 性欧美疯狂xxxxbbbb | 欧美国产亚洲日韩在线二区 | 97夜夜澡人人双人人人喊 | 日韩av无码一区二区三区不卡 | 中文字幕久久久久人妻 | 无码国产色欲xxxxx视频 | 亚洲精品久久久久avwww潮水 | 欧美性猛交内射兽交老熟妇 | 国精产品一品二品国精品69xx | 国产人妻人伦精品1国产丝袜 | 精品国产一区av天美传媒 | 99久久精品日本一区二区免费 | 亚洲一区二区三区国产精华液 | 97资源共享在线视频 | 亚洲爆乳精品无码一区二区三区 | 高潮喷水的毛片 | 色窝窝无码一区二区三区色欲 | 久久无码人妻影院 | 国产成人人人97超碰超爽8 | 国产熟妇高潮叫床视频播放 | 人妻互换免费中文字幕 | 国产精品久久久av久久久 | 蜜桃视频插满18在线观看 | 亚洲成a人片在线观看无码 | 精品 日韩 国产 欧美 视频 | 久久久久久九九精品久 | 99久久人妻精品免费一区 | 国产亚洲精品久久久久久国模美 | 国产精品.xx视频.xxtv | 疯狂三人交性欧美 | 99久久人妻精品免费一区 | 老熟女乱子伦 | 99精品无人区乱码1区2区3区 | √天堂中文官网8在线 | 久久久久久久久888 | 又大又黄又粗又爽的免费视频 | 中文字幕无码av波多野吉衣 | 在线天堂新版最新版在线8 | 一本色道久久综合狠狠躁 | 荫蒂被男人添的好舒服爽免费视频 | 无码纯肉视频在线观看 | 日韩亚洲欧美精品综合 | 夜先锋av资源网站 | 人妻插b视频一区二区三区 | ass日本丰满熟妇pics | 狂野欧美性猛交免费视频 | 国产香蕉尹人视频在线 | 亚洲色无码一区二区三区 | 亚洲熟妇色xxxxx欧美老妇 | 国产在线精品一区二区三区直播 | 无码av免费一区二区三区试看 | 亚洲人成影院在线观看 | 久久精品人人做人人综合试看 | 国产av人人夜夜澡人人爽麻豆 | 亚洲aⅴ无码成人网站国产app | 久久久久av无码免费网 | 性史性农村dvd毛片 | 婷婷综合久久中文字幕蜜桃三电影 | 欧美精品无码一区二区三区 | 午夜无码人妻av大片色欲 | 成人精品视频一区二区 | 亚洲乱码中文字幕在线 | 国产在线精品一区二区三区直播 | 成人免费视频一区二区 | 亚洲中文字幕在线观看 | 日韩亚洲欧美精品综合 | 男人和女人高潮免费网站 | 亚洲精品久久久久久一区二区 | 国产精品久久久 | 日日噜噜噜噜夜夜爽亚洲精品 | 麻豆av传媒蜜桃天美传媒 | 久久99精品国产.久久久久 | 日韩亚洲欧美精品综合 | 国产区女主播在线观看 | 亚洲国产欧美日韩精品一区二区三区 | 中文字幕 亚洲精品 第1页 | 爱做久久久久久 | 亚洲综合久久一区二区 | 日本精品久久久久中文字幕 | 老头边吃奶边弄进去呻吟 | 国产精品无码成人午夜电影 | 亚洲爆乳大丰满无码专区 | 99国产精品白浆在线观看免费 | 亚洲精品中文字幕久久久久 | 欧美亚洲日韩国产人成在线播放 | 国产一区二区三区影院 | 人人妻在人人 | 男人扒开女人内裤强吻桶进去 | 久久人人97超碰a片精品 | 秋霞成人午夜鲁丝一区二区三区 | 色噜噜亚洲男人的天堂 | 美女扒开屁股让男人桶 | 亚洲日韩av一区二区三区中文 | 亚洲va欧美va天堂v国产综合 | 永久免费观看国产裸体美女 | 在线看片无码永久免费视频 | 国产精品久久久久无码av色戒 | 女人和拘做爰正片视频 | 亚洲国产成人a精品不卡在线 | 国产农村妇女高潮大叫 | 漂亮人妻洗澡被公强 日日躁 | 久久精品国产精品国产精品污 | 一本大道久久东京热无码av | 色偷偷人人澡人人爽人人模 | 亚洲国产欧美日韩精品一区二区三区 | 亚洲va欧美va天堂v国产综合 | 永久免费观看美女裸体的网站 | 麻豆md0077饥渴少妇 | 久在线观看福利视频 | 老太婆性杂交欧美肥老太 | 成人精品天堂一区二区三区 | 亚洲成av人片在线观看无码不卡 | 亚洲另类伦春色综合小说 | 欧美性生交xxxxx久久久 | 成在人线av无码免费 | 国产无遮挡吃胸膜奶免费看 | 久久国产精品二国产精品 | 人妻无码αv中文字幕久久琪琪布 | 男女超爽视频免费播放 | 国产手机在线αⅴ片无码观看 | 国产美女精品一区二区三区 | 国产亚洲视频中文字幕97精品 | 亚洲精品久久久久中文第一幕 | 国产精品久久久久无码av色戒 | 无码午夜成人1000部免费视频 | 午夜无码区在线观看 | 日本饥渴人妻欲求不满 | 日韩av无码一区二区三区 |