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

歡迎訪問 生活随笔!

生活随笔

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

Android

谈谈 Android 中的 PathClassLoader 和 DexClassLoader

發布時間:2023/12/15 Android 62 豆豆
生活随笔 收集整理的這篇文章主要介紹了 谈谈 Android 中的 PathClassLoader 和 DexClassLoader 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這是 ZY 第 13 篇原創技術文章

預備知識

  • 了解 android 基本 ClassLoader 知識
  • 看完本文可以達到什么程度

  • 了解 PathClassLoader 和 DexClassLoader 區別
  • 文章概覽

    一、起因

    說起 Android 中的 PathClassLoader 和 DexClassLoader,先提出一個疑問,PathClassLoader 和 DexClassLoader 有什么區別呢?
    關于答案,我斗膽猜測一下,大家心中的回答一定是 PathClassLoader 是用來加載已經安裝的 apk 的,DexClassLoader 是用來加載存儲空間的 dex / apk 文件的。為什么這樣說呢,因為之前我也一直這樣理解的,而且網上大部分文章中也都是這樣講解的。
    那為何突然又談起 PathClassLoader 和 DexClassLoader 呢?起因是我在前段時間寫了一些插件化的 demo,當時忘記了 PathClassLoader 和 DexClassLoader 這回事,直接用 PathClassLoader 去加載插件了,竟然也可以加載成功???一絲絲的困惑浮現在我英俊帥氣的臉龐上,聰明的小腦瓜里打上了一個小小的問號。于是乎去翻了一下源碼,就有了這篇文章。

    二、先放結論

    先放結論,PathClassLoader 和 DexClassLoader 都能加載外部的 dex/apk,只不過區別是 DexClassLoader 可以指定 optimizedDirectory,也就是 dex2oat 的產物 .odex 存放的位置,而 PathClassLoader 只能使用系統默認位置。但是這個 optimizedDirectory 在 Android 8.0 以后也被舍棄了,只能使用系統默認的位置了。

    我們這里先基于 android 5.0 代碼來分析,然后再看看其他系統版本的一些區別。(選取 5.0 是因為此時 art 的源碼還比較簡單~)

    三、ClassLoader 的構造函數

    3.1 BaseDexClassLoader 構造函數

    PathClassLoader 和 DexClassLoader 都是繼承了 BaseDexClassLoader,這里先看一下。 BaseDexClassLoader 的構造函數。

    public class BaseDexClassLoader extends ClassLoader {private final DexPathList pathList;/*** Constructs an instance.** @param dexPath the list of jar/apk files containing classes and* resources, delimited by {@code File.pathSeparator}, which* defaults to {@code ":"} on Android* @param optimizedDirectory directory where optimized dex files* should be written; may be {@code null}* @param libraryPath the list of directories containing native* libraries, delimited by {@code File.pathSeparator}; may be* {@code null}* @param parent the parent class loader*/public BaseDexClassLoader(String dexPath, File optimizedDirectory,String libraryPath, ClassLoader parent) {super(parent);this.pathList = new DexPathList(this, dexPath, libraryPath, optimizedDirectory);} } 復制代碼

    BaseDexClassLoader 構造函數有四個參數,含義如下:

    • dexPath: 需要加載的文件列表,文件可以是包含了 classes.dex 的 JAR/APK/ZIP,也可以直接使用 classes.dex 文件,多個文件用 “:” 分割
    • optimizedDirectory: 存放優化后的 dex,可以為空
    • libraryPath: 存放需要加載的 native 庫的目錄
    • parent: 父 ClassLoader

    通過構造函數我們大概可以了解到 BaseDexClassLoader 的運行方式,傳入 dex 文件,然后進行優化,保存優化后的 dex 文件到 optimizedDirectory 目錄。

    3.2 PathClassLoader 構造函數

    接著我們再看 PathClassLoader 的構造函數。

    /*** Provides a simple {@link ClassLoader} implementation that operates on a list* of files and directories in the local file system, but does not attempt to* load classes from the network. Android uses this class for its system class* loader and for its application class loader(s).*/ public class PathClassLoader extends BaseDexClassLoader {public PathClassLoader(String dexPath, ClassLoader parent) {super(dexPath, null, null, parent);}/*** Creates a {@code PathClassLoader} that operates on two given* lists of files and directories. The entries of the first list* should be one of the following:** <ul>* <li>JAR/ZIP/APK files, possibly containing a "classes.dex" file as* well as arbitrary resources.* <li>Raw ".dex" files (not inside a zip file).* </ulyanzheng>** The entries of the second list should be directories containing* native library files.** @param dexPath the list of jar/apk files containing classes and* resources, delimited by {@code File.pathSeparator}, which* defaults to {@code ":"} on Android* @param libraryPath the list of directories containing native* libraries, delimited by {@code File.pathSeparator}; may be* {@code null}* @param parent the parent class loader*/public PathClassLoader(String dexPath, String libraryPath,ClassLoader parent) {super(dexPath, null, libraryPath, parent);} } 復制代碼

    關于 PathClassLoader 有一點稍微注意一下,代碼注釋中對 PathClassLoader 的介紹是,用來操作文件系統上的一系列文件和目錄 的 ClassLoader 實現。其中并沒有提到只能加載安裝后的 apk 文件。
    PathClassLoader 有兩個構造函數,區別在于傳給 BaseDexClassLoader 的 libraryPath 是否為空。最終調用 BaseDexClassLoader 構造函數時,傳入的 optimizedDirectory 為空。

    3.3 DexClassLoader 構造函數

    再來看看 DexClassLoader 的構造函數。和 BaseDexClassLoader 構造函數的參數是一樣的。

    public class DexClassLoader extends BaseDexClassLoader {/*** Creates a {@code DexClassLoader} that finds interpreted and native* code. Interpreted classes are found in a set of DEX files contained* in Jar or APK files.** <p>The path lists are separated using the character specified by the* {@code path.separator} system property, which defaults to {@code :}.** @param dexPath the list of jar/apk files containing classes and* resources, delimited by {@code File.pathSeparator}, which* defaults to {@code ":"} on Android* @param optimizedDirectory directory where optimized dex files* should be written; must not be {@code null}* @param librarySearchPath the list of directories containing native* libraries, delimited by {@code File.pathSeparator}; may be* {@code null}* @param parent the parent class loader*/public DexClassLoader(String dexPath, String optimizedDirectory,String librarySearchPath, ClassLoader parent) {super(dexPath, new File(optimizedDirectory), librarySearchPath, parent);} } 復制代碼

    通過上面對構造函數的分析,我們可以明白,PathClassLoader 和 DexClassLoader 關鍵不同點,在 optimizedDirectory 參數上,PathClassLoader 傳入的是 null,而 DexClassLoader 傳入的是用戶指定的目錄。

    四、optimizedDirectory 參數的處理

    既然知道了區別在 optimizedDirectory,那就來看看 BaseDexClassLoader 里是怎么處理 optimizedDirectory 的。

    4.1 DexPathList 處理

    在 BaseDexClassLoader 里,直接將 optimizedDirectory 透傳給了 DexPathList。 這里先簡單介紹一下 DexPathList。 DexPathList 里有兩個成員變量,dexElements 用來保存 dex 和資源列表,nativeLibraryDirectories 用來保存 native 庫列表。

    class DexPathList {private final Element[] dexElements;private final File[] nativeLibraryDirectories; } 復制代碼

    在 DexPathList 中,使用 optimizedDirectory 的路徑是:

    DexPathList -> makeDexElements -> loadDexFile 復制代碼

    這里要看一下 loadDexFile 方法。

    class DexPathList {private static DexFile loadDexFile(File file, File optimizedDirectory)throws IOException {if (optimizedDirectory == null) {return new DexFile(file);} else {String optimizedPath = optimizedPathFor(file, optimizedDirectory);return DexFile.loadDex(file.getPath(), optimizedPath, 0);}} } 復制代碼

    在 DexPathList 中,會為每一個 DEX 文件創建一個 DexFile 對象,創建方式有兩種,optimizedDirectory 為空時,調用 DexFile(file) 創建,否則調用 DexFile.loadDex()。
    這樣對于 optimizedDirectory 的處理就流轉到 DexFile 里了。

    4.2 DexFile 處理

    其實在 DexFile.loadDex 里,也是直接調用了 DexFile 的構造函數

    class DexFile {public DexFile(File file) throws IOException {this(file.getPath());}public DexFile(String fileName) throws IOException {// 調用 openDexFile 處理 dexmCookie = openDexFile(fileName, null, 0);mFileName = fileName;guard.open("close");}private DexFile(String sourceName, String outputName, int flags) throws IOException {// ...// 調用 openDexFile 處理 dexmCookie = openDexFile(sourceName, outputName, flags);mFileName = sourceName;guard.open("close");}static public DexFile loadDex(String sourcePathName, String outputPathName,int flags) throws IOException {return new DexFile(sourcePathName, outputPathName, flags);}private static long openDexFile(String sourceName, String outputName, int flags) throws IOException {// 最終調用 native 方法return openDexFileNative(new File(sourceName).getAbsolutePath(),(outputName == null) ? null : new File(outputName).getAbsolutePath(),flags);}private static native long openDexFileNative(String sourceName, String outputName, int flags); } 復制代碼

    DexFile 代碼不多,上面基本上就是主要代碼了。我們可以看到,不管調用 DexFile 哪個構造函數,最后都會通過 openDexFileNative 進行處理,區別就在于 outputName 參數是否為空,而 outputName 參數,就是上面一路傳遞下來的 optimizeDirectory 參數。
    我們再回顧一下調用的鏈路:

    PathClassLoader.constructor / DexClassLoader.constructor -> BaseDexClassLoader.constructor -> DexPathList.constructor -> DexPathList.makeDexElements -> DexPathList.loadDexFile -> DexFile.constructor / DexFile.loadDex -> DexFile.openDexFile -> DexFile.openDexFileNative 復制代碼

    再繼續往下看,就走到了 native 邏輯。native 邏輯可以下載 art 源碼對照查看。

    4.3 native 處理

    openDexFileNative 對應的 native 邏輯在 dalvik_system_DexFile.cc 里的 DexFile_openDexFileNative 方法。
    在 DexFile_openDexFileNative 里主要做事情是處理 DEX 文件,并生成 .odex 文件到 optimizedDirectory 里。
    這里關于 optimizedDirectory 的處理路徑是:

    DexFile_openDexFileNative -> ClassLinker::OpenDexFilesFromOat 復制代碼

    在 OpenDexFilesFromOat 里有這樣一段處理邏輯:

    ClassLinker::OpenDexFilesFromOat() {// ...if (oat_location == nullptr) {// 如果 oat_location 為空,就使用默認的 dalvikcache const std::string dalvik_cache(GetDalvikCacheOrDie(GetInstructionSetString(kRuntimeISA)));cache_location = GetDalvikCacheFilenameOrDie(dex_location, dalvik_cache.c_str());oat_location = cache_location.c_str();}// ...if (Runtime::Current()->IsDex2OatEnabled() && has_flock && scoped_flock.HasFile()) {// Create the oat file.open_oat_file.reset(CreateOatFileForDexLocation(dex_location, scoped_flock.GetFile()->Fd(),oat_location, error_msgs));} } 復制代碼

    上面方法里的 oat_location 就是 optimizeDirectory 傳入到 native 中的化身。這里有一個判斷邏輯,如果 oat_location 為空的話,就采用默認的 dalvikcache 路徑。之后調用 CreateOatFileForDexLocation 去優化 DEX 文件了。
    而 dalvikcache 是通過 GetDalvikCacheOrDie 獲取的。

    // art/runtime/utils.cc std::string GetDalvikCacheOrDie(const char* subdir, const bool create_if_absent) {CHECK(subdir != nullptr);// 這里的 AndroidData 就是 /data 目錄const char* android_data = GetAndroidData();const std::string dalvik_cache_root(StringPrintf("%s/dalvik-cache/", android_data));const std::string dalvik_cache = dalvik_cache_root + subdir;if (create_if_absent && !OS::DirectoryExists(dalvik_cache.c_str())) {// Don't create the system's /data/dalvik-cache/... because it needs special permissions.if (strcmp(android_data, "/data") != 0) {int result = mkdir(dalvik_cache_root.c_str(), 0700);if (result != 0 && errno != EEXIST) {PLOG(FATAL) << "Failed to create dalvik-cache directory " << dalvik_cache_root;return "";}result = mkdir(dalvik_cache.c_str(), 0700);if (result != 0) {PLOG(FATAL) << "Failed to create dalvik-cache directory " << dalvik_cache;return "";}} else {LOG(FATAL) << "Failed to find dalvik-cache directory " << dalvik_cache;return "";}}return dalvik_cache; } 復制代碼

    GetDalvikCacheOrDie 獲取的就是 /data/dalvik-cache/ 目錄。
    這里我們回顧一下之前提出的問題,避免迷失在茫茫代碼中。
    我們的問題是 optimizedDirectory 參數傳空和不為空有什么區別,PathClassLoader 傳入的 optmizedDirectory 為空,而 DexClassLoader 傳入的 optimizedDirectory 是用戶自定義的目錄。
    回看一下調用鏈路。

    PathClassLoader.constructor / DexClassLoader.constructor -> BaseDexClassLoader.constructor -> DexPathList.constructor -> DexPathList.makeDexElements -> DexPathList.loadDexFile -> DexFile.constructor / DexFile.loadDex -> DexFile.openDexFile -> DexFile.openDexFileNative -> DexFile_openDexFileNative -> ClassLinker::OpenDexFilesFromOat 復制代碼

    到這里我們就可以得出結論了,optmizedDirectory 不為空時,使用用戶定義的目錄作為 DEX 文件優化后產物 .odex 的存儲目錄,為空時,會使用默認的 /data/dalvik-cache/ 目錄。
    所以印證了開頭的結論,PathClassLoader 其實并不是只能加載安裝后的 APK,也可以加載其他 DEX/JAR/APK 文件,只不過生成的 .odex 文件只能存儲在系統默認路徑下。
    被誤導多年的謎題終于解開了。耳邊不禁響起柯南破案的 BGM。

    五、其他系統版本上進行驗證

    不過上述的分析是在 5.0 源碼下進行的,我們再選取 4.4 和 8.0 看一下。
    為什么選取這兩個版本呢?首先 4.4 和 5.0 是 ART 和 Dalvik 的分水嶺,而 8.0 以后對 PathClassLoader 有些改動。

    5.1 Android 4.4

    有了上面的分析基礎,我們分析 4.4 的代碼就順暢的多了。一路從 Java 分析到 native。 Java 層代碼沒有什么變動,native 的入口還是 DexFile_openDexFileNative。之后的代碼就有了些許不一樣。

    DexFile_openDexFileNative() {// ...if (outputName.c_str() == NULL) {dex_file = linker->FindDexFileInOatFileFromDexLocation(dex_location, dex_location_checksum);} else {std::string oat_location(outputName.c_str());dex_file = linker->FindOrCreateOatFileForDexLocation(dex_location, dex_location_checksum, oat_location);}// ... } 復制代碼

    這里和 5.0 的區別就是 根據 outputName 也就是 optimizedDirectory 是否為空,調用了兩個不同的函數。 而 FindDexFileInOatFileFromDexLocation 里的邏輯就又有些熟悉了。

    ClassLinker::FindDexFileInOatFileFromDexLocation() {// ...std::string oat_cache_filename(GetDalvikCacheFilenameOrDie(dex_location));return FindOrCreateOatFileForDexLocationLocked(dex_location, dex_location_checksum, oat_cache_filename); } 復制代碼

    默認也是獲取到 dalvikcache 目錄作為 .odex 文件的存儲路徑。

    5.2 Android 8.0

    在 8.0 系統上,事情發生了一些微弱的變化,我們看看 BaseDexClassLoader 的構造函數。

    class BaseDexClassLoader {/*** Constructs an instance.* Note that all the *.jar and *.apk files from {@code dexPath} might be* first extracted in-memory before the code is loaded. This can be avoided* by passing raw dex files (*.dex) in the {@code dexPath}.** @param dexPath the list of jar/apk files containing classes and* resources, delimited by {@code File.pathSeparator}, which* defaults to {@code ":"} on Android.* @param optimizedDirectory this parameter is deprecated and has no effect* @param librarySearchPath the list of directories containing native* libraries, delimited by {@code File.pathSeparator}; may be* {@code null}* @param parent the parent class loader*/public BaseDexClassLoader(String dexPath, File optimizedDirectory,String librarySearchPath, ClassLoader parent) {super(parent);this.pathList = new DexPathList(this, dexPath, librarySearchPath, null);if (reporter != null) {reporter.report(this.pathList.getDexPaths());}} } 復制代碼

    一個很明顯的變化就是,optimizedDirectory 被棄用了,傳給 DexPathList 的 optimizedDirectory 直接為空,不管外面傳進來什么值。 也就是說,在 8.0 上,PathClassLoader 和 DexClassLoader 其實已經沒有什么區別了。DexClassLoader 也不能指定 optimizedDirectory 了。

    而在 DexFile_openDexFileNative 中,可以看到,javaOutputName 參數也已經被棄用了。

    static jobject DexFile_openDexFileNative(JNIEnv* env,jclass,jstring javaSourceName,jstring javaOutputName ATTRIBUTE_UNUSED,jint flags ATTRIBUTE_UNUSED,jobject class_loader,jobjectArray dex_elements) { } 復制代碼

    之后對 DEX 文件的處理鏈路如下:

    DexFile_openDexFileNative -> DexLocationToOdexNames -> OatFileManager::OpenDexFilesFromOat -> OatFileAssistant::OatFileAssistant -> OatFileAssistant::DexLocationToOdexFilename -> DexLocationToOdexNames 復制代碼

    在 DexLocationToOdexNames 方法里,對 .odex 文件的路徑做了處理。

    static bool DexLocationToOdexNames(const std::string& location,InstructionSet isa,std::string* odex_filename,std::string* oat_dir,std::string* isa_dir,std::string* error_msg) {CHECK(odex_filename != nullptr);CHECK(error_msg != nullptr);// The odex file name is formed by replacing the dex_location extension with// .odex and inserting an oat/<isa> directory. For example:// location = /foo/bar/baz.jar// odex_location = /foo/bar/oat/<isa>/baz.odex// Find the directory portion of the dex location and add the oat/<isa>// directory.size_t pos = location.rfind('/');if (pos == std::string::npos) {*error_msg = "Dex location " + location + " has no directory.";return false;}std::string dir = location.substr(0, pos+1);// Add the oat directory.dir += "oat";if (oat_dir != nullptr) {*oat_dir = dir;}// Add the isa directorydir += "/" + std::string(GetInstructionSetString(isa));if (isa_dir != nullptr) {*isa_dir = dir;}// Get the base part of the file without the extension.std::string file = location.substr(pos+1);pos = file.rfind('.');if (pos == std::string::npos) {*error_msg = "Dex location " + location + " has no extension.";return false;}std::string base = file.substr(0, pos);*odex_filename = dir + "/" + base + ".odex";return true; } 復制代碼

    看到上面的處理就是在 DEX 文件同級目錄下添加一個 oat/ 文件作為 .odex 的存儲目錄。

    總結

    關于我

    創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

    總結

    以上是生活随笔為你收集整理的谈谈 Android 中的 PathClassLoader 和 DexClassLoader的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    久久国产精品影片 | 色狠狠综合天天综合综合 | 五月婷综合 | 色天天久久 | 亚洲黄色免费网站 | 日韩电影一区二区在线观看 | 99国产在线| 亚洲视频,欧洲视频 | 天天爽天天射 | 成人精品一区二区三区中文字幕 | 最新av免费在线观看 | 国产永久免费高清在线观看视频 | 日本精品免费看 | 黄色一二级片 | 久久久一本精品99久久精品66 | 日本黄网站 | 成人app在线播放 | 国产午夜影院 | 国产清纯在线 | 国产美女精品视频 | 亚洲 欧洲av| wwwav视频| 国产精品观看 | 欧美一区二区三区在线视频观看 | 免费在线观看av网站 | 天天操狠狠操 | 中文在线a√在线 | 一区二区三区在线观看 | 天天操天天爱天天爽 | 九色91av| 亚洲精品福利在线 | 91av资源在线 | 国产精品婷婷午夜在线观看 | 在线视频精品 | av久久在线 | 亚洲日本在线视频观看 | 久久有精品| 操高跟美女 | 免费进去里的视频 | 波多野结衣最新 | 日韩特级毛片 | 麻豆高清免费国产一区 | 成人av电影在线播放 | av三级在线免费观看 | 91网页版免费观看 | 欧美亚洲三级 | 免费看的黄色的网站 | 欧美有色| 91porny九色91啦中文 | 美女久久视频 | 久久系列 | av在线之家电影网站 | 免费看黄在线观看 | 97色在线观看免费视频 | 91在线国内视频 | 国产在线91精品 | 欧美日韩一区二区免费在线观看 | 涩涩资源网 | a视频免费在线观看 | 2019中文| 9i看片成人免费看片 | 奇米网777 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 国产免费观看视频 | 久久免费的精品国产v∧ | 色婷婷视频在线观看 | 免费黄色在线播放 | 久久不卡国产精品一区二区 | 麻豆传媒在线免费看 | 97免费在线观看 | 瑞典xxxx性hd极品 | 成人免费在线观看入口 | 久久se视频 | 久久久国产精品成人免费 | 国产精品久久久网站 | www.伊人网 | 在线电影日韩 | 8x8x在线观看视频 | 国产日韩一区在线 | 国产第一二区 | 日韩视频在线不卡 | 三级黄色a | 91精品久久久久久 | 伊人五月婷 | 免费看网站在线 | 久久久久日本精品一区二区三区 | 欧美一区二区三区在线播放 | 偷拍区另类综合在线 | 欧美成人久久 | 成人四虎| 在线观看91久久久久久 | 欧美精品亚洲精品日韩精品 | 五月综合 | 国产精品福利在线播放 | 在线黄色av | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 国产精品热视频 | 亚洲理论片在线观看 | japanesefreesex中国少妇 | 手机看片福利 | 免费黄色在线 | 国产美女视频 | 国产成人av | 337p西西人体大胆瓣开下部 | 激情开心网站 | 天天色视频 | 91三级在线观看 | 国产美女在线免费观看 | 免费高清看电视网站 | 91九色在线视频观看 | 色偷偷88欧美精品久久久 | 精品国产一区二区三区久久久蜜臀 | 久久免费久久 | 在线播放亚洲 | 在线小视频你懂的 | 麻豆国产视频下载 | 成人在线视频在线观看 | 四虎海外影库www4hu | 久草视频免费播放 | 免费性网站 | 人人揉人人揉人人揉人人揉97 | 国产视频在线一区二区 | 最近高清中文在线字幕在线观看 | 国产又粗又猛又爽又黄的视频先 | 久久av中文字幕片 | 亚洲天堂毛片 | 九九久久影视 | www.玖玖玖| 一级一级一片免费 | 91探花国产综合在线精品 | 91在线一区二区 | av网站免费看| 国产精品久久久久久久久久免费看 | 99精品久久只有精品 | 激情电影在线观看 | 97在线观看免费高清 | 综合亚洲视频 | 国产日韩一区在线 | 成人小视频在线 | 欧美一级爽 | 在线视频区 | 一区二区三区高清在线观看 | 黄色aaa毛片 | 国产精品成人一区二区三区吃奶 | 中文字幕精品一区久久久久 | 在线观看成人一级片 | 精品99视频 | 在线午夜电影神马影院 | 毛片激情永久免费 | 在线观看国产一区二区 | 日韩激情免费视频 | 久久综合99 | 国产精品久久久av | www.色com| 久久久这里有精品 | 98久9在线 | 免费 | 国产精品国产三级国产aⅴ入口 | 国产精品淫 | 97精品在线视频 | 成人中文字幕在线观看 | 久久avav| 亚洲va天堂va欧美ⅴa在线 | 久久综合九色综合久久久精品综合 | 国产高清av免费在线观看 | 精品视频免费观看 | 男女视频久久久 | 99视频在线精品免费观看2 | 在线播放视频一区 | 欧美一级片在线观看视频 | 91社区国产高清 | 免费视频xnxx com | 开心激情婷婷 | 亚洲久草在线 | 国产999免费视频 | 精品视频99 | 日b视频在线观看网址 | 日韩精品一区二区三区在线视频 | 久久久私人影院 | 国产丝袜一区二区三区 | 国产91精品久久久久久 | 九九久久成人 | 丝袜制服综合网 | 免费在线成人av | 久久夜视频 | 国产精品福利在线观看 | 亚洲精品xxxx| 制服丝袜欧美 | 久久国产精品二国产精品中国洋人 | 国产成人精品一区二三区 | 国产精彩在线视频 | 91看片淫黄大片一级在线观看 | 四虎免费在线观看 | 综合色伊人 | 伊人中文网 | 久久免费高清视频 | 91精品国产91久久久久 | 99国产精品视频免费观看一公开 | 久久久久精| 久久99电影 | www.伊人色.com | 久99久精品| 91九色蝌蚪在线 | 黄污网站在线观看 | 国产精品大全 | 欧美成人视 | 久久综合久久88 | 国产在线精品福利 | 亚洲韩国一区二区三区 | 日韩精品在线免费播放 | 亚洲一区久久 | 日韩电影久久 | 国产精品11 | 亚洲黄色免费在线看 | 五月婷婷激情综合网 | 激情av综合 | 日韩中文字幕a | 91福利视频免费观看 | 日韩中文字幕a | 国产精品九九九九九九 | 天天操天天干天天插 | 亚洲专区一二三 | 天天操天天能 | 在线观看中文字幕 | 九九免费在线观看视频 | 亚洲aⅴ乱码精品成人区 | 久久国产精品二国产精品中国洋人 | 久久免费视频这里只有精品 | 国产中年夫妇高潮精品视频 | 国产精品高清在线 | 亚洲区精品视频 | 日日弄天天弄美女bbbb | 色综合久久精品 | 国产精品久久中文字幕 | 色婷婷在线视频 | 在线播放一区二区三区 | 久久五月天综合 | 麻豆视频在线免费看 | 免费a级观看 | 国产一区视频导航 | 99热这里是精品 | 亚洲国产精品成人va在线观看 | 精品免费99久久 | 亚州中文av | 一级黄色在线免费观看 | 99免费视频 | 毛片www| 在线视频你懂得 | 欧美性大胆 | 亚洲午夜久久久久久久久 | 91麻豆精品国产 | 久久97久久97精品免视看 | 97精品欧美91久久久久久 | 日本在线观看视频一区 | 99人久久精品视频最新地址 | 婷婷色视频 | 日韩高清在线一区二区 | 激情深爱.com | 又黄又爽又无遮挡免费的网站 | 日产av在线播放 | 久久第四色 | 久久久久久久免费 | 色婷婷 亚洲 | 97色在线观看 | 久久久久女教师免费一区 | 国产视频一区在线 | 国产又粗又猛又色又黄网站 | 日韩中文字幕在线不卡 | 亚洲欧洲日韩在线观看 | 在线观看精品视频 | 国产精品乱码久久久 | 激情av在线播放 | 在线观看国产一区二区 | 成年人视频在线免费播放 | 91在线资源 | 国产片免费在线观看视频 | 亚洲国产精品成人va在线观看 | 中文字幕一区二区三区视频 | 久久精品理论 | 91看片在线看片 | 丰满少妇在线观看 | 久久五月天色综合 | 最近久乱中文字幕 | 视频二区在线 | 中文字幕欧美激情 | 国产精品高清av | 射久久久 | 九九九免费视频 | 国产精品原创在线 | 国产成人亚洲在线电影 | 久久免费视频精品 | 国产精品第一页在线 | 欧美成年网站 | 91亚洲精品久久久久图片蜜桃 | 国产理论一区二区三区 | 中文字幕免费 | 国产1级毛片| 91在线观 | 有码中文字幕在线观看 | 久久夜靖品 | 久久电影网站中文字幕 | 国语黄色片 | 成人性生交大片免费观看网站 | 麻豆一区二区 | 国产精品不卡在线 | 日韩电影精品一区 | a在线观看国产 | 中文字幕一区二区三区四区久久 | 日韩精品久久一区二区 | 国产一区二区三区免费视频 | 欧美在线一二 | 精品伊人久久久 | 国产精品久久久久久爽爽爽 | 丁香六月五月婷婷 | 国产精品毛片一区视频播 | 亚洲经典中文字幕 | 一区 在线 影院 | 97在线精品国自产拍中文 | 超碰国产在线观看 | 国产护士av | 激情综合网五月 | 五月天欧美精品 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 欧美精品久久久久久久 | 人人玩人人添人人 | 一级欧美黄 | 国产在线视频在线观看 | 激情文学综合丁香 | 99精品久久只有精品 | 国产精品久久久区三区天天噜 | 亚洲高清视频在线播放 | 久久久久久久久久久国产精品 | 久久综合五月天婷婷伊人 | 伊甸园av在线 | 97超碰在线免费观看 | 超级av在线| 中文国产字幕 | 久久综合九色综合久久久精品综合 | 免费午夜av | 特黄一级毛片 | wwwwww黄| 在线免费色视频 | 久久综合之合合综合久久 | 日韩精品一区二区三区免费观看视频 | 久久久久久久免费观看 | 日韩城人在线 | 在线免费黄色毛片 | 日韩精品视| 丁香影院在线 | 久久精品91久久久久久再现 | 久久免费99 | 国产免费视频一区二区裸体 | 88av网站| 五月天亚洲激情 | 91精品电影 | 亚洲综合色婷婷 | 伊人伊成久久人综合网站 | 精品久久久久久国产91 | 日韩久久精品一区二区三区下载 | 欧美一区二区三区激情视频 | 91亚洲精品国偷拍 | 国产亚洲成av片在线观看 | 日本黄色免费观看 | 成人毛片100免费观看 | 在线影院 国内精品 | 在线免费观看av网站 | 亚洲精品视频在线观看视频 | 天天色天天综合 | 久久免费激情视频 | 人人狠狠 | 亚洲激情在线观看 | 午夜91视频 | 国产剧情av在线播放 | 黄色av一级片 | 狠狠88综合久久久久综合网 | 日韩激情在线 | 精品国产乱码 | 黄色国产精品 | 国产精品18久久久久vr手机版特色 | 三级在线国产 | 国产黄色精品在线 | 久草综合在线 | 深爱婷婷 | 在线电影 一区 | a在线免费观看视频 | 日韩在线精品一区 | 人人干97| 国产一区视频在线观看免费 | 亚洲 中文 欧美 日韩vr 在线 | 免费合欢视频成人app | 一二三区高清 | 中文字幕在线播放日韩 | 最新91在线视频 | 一区二区三区电影大全 | 亚洲精品国精品久久99热一 | 亚洲va欧美| 国产另类av | 日韩精品久久久久久中文字幕8 | 欧美日韩在线观看一区二区 | 日韩av男人的天堂 | 91视频a | 国产韩国日本高清视频 | 超碰人人在线 | 特级西西444www大精品视频免费看 | 日韩av资源在线观看 | 久久婷婷国产色一区二区三区 | 天天爽夜夜操 | 日韩深夜在线观看 | 日本精品一区二区三区在线观看 | 色www免费视频 | 亚洲国产精品久久久久 | 国产一级二级视频 | 久久久精品欧美一区二区免费 | 久久不见久久见免费影院 | 久久久久一区二区三区 | 美女网站色在线观看 | 国产精品精品国产婷婷这里av | 亚洲一区二区三区四区在线视频 | 亚洲不卡av一区二区三区 | 久久电影日韩 | 精品无人国产偷自产在线 | 日本深夜福利视频 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 超碰人人在线 | 在线99视频 | 久草在线久草在线2 | 国产亚洲va综合人人澡精品 | 综合色中文 | 日韩中文字幕第一页 | 国产午夜精品一区二区三区欧美 | 国产高清中文字幕 | 97碰碰视频| 久久久久久久久久久久久久av | 六月丁香综合 | 国产精品美乳一区二区免费 | 黄色精品视频 | 国产高清在线精品 | 久久伊99综合婷婷久久伊 | 99久久精品久久久久久动态片 | 天天干天天想 | 天无日天天操天天干 | 狠狠狠狠狠干 | 欧美日韩国产色综合一二三四 | 日本久久久久久 | 久久久久国产精品午夜一区 | 成人网色 | 中文字幕超清在线免费 | 亚洲精品国精品久久99热一 | 国产亚洲激情视频在线 | 美女视频是黄的免费观看 | 人人爽人人爽人人爽 | 精品福利在线视频 | 欧美了一区在线观看 | 国产精品毛片完整版 | 奇米影视四色8888 | 欧美乱大交 | 亚洲国产成人久久综合 | 狠狠色狠狠色综合日日92 | 久草在线视频免费资源观看 | 久久久久久久久综合 | 天堂av在线7 | 成人久久久电影 | 亚洲更新最快 | 午夜精品视频免费在线观看 | 欧美日韩在线观看一区二区三区 | 中文字幕久久久精品 | 日韩免费三区 | 永久中文字幕 | 欧洲亚洲国产视频 | 嫩草伊人久久精品少妇av | 国产成人精品亚洲日本在线观看 | 九九交易行官网 | 色欧美综合 | 国产精品地址 | 91精品视频一区 | 天天综合网在线观看 | 伊人婷婷网| 国产在线免费 | aa级黄色大片 | 天天干,夜夜爽 | 美女网站在线免费观看 | 日韩免费电影网站 | 最近2019年日本中文免费字幕 | 久久精品久久久久电影 | 成人毛片一区 | 在线只有精品 | 在线免费观看亚洲视频 | 中文字幕在线播放一区 | 在线观看免费国产小视频 | 日韩精品久久久久 | 日韩va亚洲va欧美va久久 | 久精品视频 | 日韩欧美综合精品 | 成年人黄色免费看 | 久久精品久久综合 | www国产亚洲| 久久专区| 欧美日韩1区 | 园产精品久久久久久久7电影 | 国产一区二区久久久久 | 99riav1国产精品视频 | 97看片网 | 91av大全 | 久久久夜色 | 国产精品综合久久久久 | 天天操综合| 天天色官网 | 在线视频精品 | 国产精品一区在线播放 | 夜夜操网站 | 日韩欧美一二三 | 国产精品亚洲人在线观看 | 国产精久久久久久妇女av | 色播激情五月 | 在线精品观看国产 | 又黄又爽又湿又无遮挡的在线视频 | 日韩在线观看三区 | 免费成人看片 | 久草在线手机视频 | 婷婷九月激情 | 久久黄网站| 日日干综合 | 亚洲视频观看 | 免费观看mv大片高清 | 波多野结衣在线观看一区二区三区 | 日韩极品在线 | 亚洲 欧洲av | 不卡电影一区二区三区 | 天天操操 | 香蕉视频在线看 | 一二三精品视频 | 色婷婷五| 中文字幕在线观看资源 | 成人在线视频免费观看 | 毛片99| 久久午夜精品影院一区 | 中文字幕欧美日韩va免费视频 | 久草剧场 | 91成人在线免费观看 | 免费观看一区二区 | www.狠狠插.com | 亚洲精品久久视频 | 婷婷在线网 | 一级黄色片毛片 | 久久久久久国产精品 | 国产精品中文字幕在线 | 丁香六月婷婷开心 | 91丨九色丨国产丨porny精品 | 五月花婷婷 | 一区二区三区四区免费视频 | 91色国产在线| 中午字幕在线 | 免费在线观看中文字幕 | 日韩亚洲在线 | 日韩精品一区二区三区三炮视频 | 在线观看精品一区 | 五月天激情综合网 | 日本 在线 视频 中文 有码 | 久久国产综合视频 | 免费黄色小网站 | 国产精品原创av片国产免费 | 麻豆视频入口 | av官网在线| 91色九色 | 美女精品 | 午夜一级免费电影 | 久久久久久久久久久黄色 | 五月天.com | 中日韩在线视频 | 久久国产免费视频 | 精品女同一区二区三区在线观看 | 亚洲黄色a| 91高清免费看 | 成人在线观看免费 | 国产在线精品二区 | 一级片观看 | 91麻豆高清视频 | 久久精品视频在线播放 | 日韩在线视频免费观看 | 国产二区视频在线观看 | www91在线观看 | 亚洲成人黄色网址 | 国产亚洲一级高清 | 中文字幕123区 | 午夜视频在线瓜伦 | 黄色大片av| 在线国产专区 | 久久专区 | 人人澡澡人人 | 国产91国语对白在线 | 久久久久国产精品一区 | 久久爽久久爽久久av东京爽 | 国产一区二区免费 | 亚洲国产中文字幕在线观看 | 激情偷乱人伦小说视频在线观看 | 日本成人免费在线观看 | 四虎天堂 | 久久久久久中文字幕 | 中文在线字幕免 | 久久视频国产精品免费视频在线 | 久久国产精品久久久久 | 最近中文字幕在线中文高清版 | 久久久久久久久久久精 | 国产精品欧美日韩在线观看 | 亚洲 欧洲av | 九九久久成人 | 日韩在线不卡视频 | 天天干,天天草 | 手机看片99 | 中文在线免费观看 | 99视频精品全国免费 | 国产精品美女免费 | 欧美aaa一级 | a v在线视频 | 国产成人精品午夜在线播放 | 国产精品一区二区白浆 | 九九交易行官网 | 中文免费| 99精品一区二区三区 | 国产精品11 | www.久久免费视频 | 国产精品都在这里 | 亚洲年轻女教师毛茸茸 | 免费观看性生交 | 精品99在线 | 日本护士撒尿xxxx18 | 久久精品精品电影网 | 国产成人av| 在线免费观看麻豆视频 | 日日爱av | 久久一本综合 | 中文字幕免费观看视频 | 99久久这里只有精品 | 国产黑丝一区二区三区 | 亚洲午夜精品福利 | 国产操在线 | 9999在线视频| 久久r精品| 欧美极品xxxx| 久热精品国产 | 中文在线a天堂 | 色综合久 | 三级毛片视频 | 狠狠干激情 | 日本福利视频在线 | 99这里精品 | 欧美日韩高清一区二区 | 伊人看片| 安徽妇搡bbbb搡bbbb | 日韩精品免费一区二区三区 | 日韩欧美成 | 欧美日韩精品二区第二页 | 粉嫩av一区二区三区入口 | 99热在线这里只有精品 | 天天插视频 | 欧美久久久久久久久久 | a资源在线| 国产黄色大片免费看 | 国产成人精品久久久久蜜臀 | 欧美精品做受xxx性少妇 | a级片韩国| 亚洲aaa毛片 | 手机av电影在线观看 | 久久综合免费 | 国产自产在线视频 | 国产免费精彩视频 | 精品国产乱码久久久久久久 | 亚洲好视频| 国产成视频在线观看 | 成人av影视 | 在线久草视频 | www.国产在线 | 免费男女羞羞的视频网站中文字幕 | 国产精品久久久久久999 | 91精彩在线视频 | 国产91国语对白在线 | 欧美精品视 | 九九欧美视频 | 综合久久婷婷 | 黄网站色视频免费观看 | 日韩一区二区免费在线观看 | 91大神精品视频在线观看 | 91桃色在线观看视频 | 99国产精品| 成人精品久久久 | 免费一级片久久 | 99自拍视频在线观看 | 免费视频在线观看网站 | 黄色三几片| 国产精品毛片一区二区在线看 | 狠狠激情中文字幕 | 国产大片免费久久 | 一区二区三区 亚洲 | 色999五月色 | 91资源在线免费观看 | 精品免费久久久久久 | 国产亚洲情侣一区二区无 | 国产在线一区观看 | 西西4444www大胆视频 | 亚洲午夜久久久久 | 91麻豆文化传媒在线观看 | 久艹在线观看视频 | 久久精品99 | 成人免费观看a | 激情网站免费观看 | 日韩,精品电影 | 玖玖视频在线 | 色综合久久五月 | 中文字幕在线一区二区三区 | 在线日韩视频 | 99久久日韩精品免费热麻豆美女 | 黄色片免费看 | 久久免费看a级毛毛片 | 亚洲高清在线观看视频 | 欧美久久99| freejavvideo日本免费 | 精品国产一区二区三区噜噜噜 | 黄色网www | 欧美日韩另类在线 | 亚洲精品国偷拍自产在线观看蜜桃 | 欧美 日韩精品 | 91亚洲精品乱码久久久久久蜜桃 | 国产免费影院 | 欧美精品一区二区免费 | 蜜臀久久99精品久久久无需会员 | 色资源网在线观看 | 久久免费在线 | 久久久资源网 | 在线黄网站| 日韩在线观看电影 | 国内少妇自拍视频一区 | 国产成人精品久久二区二区 | 亚洲激情在线视频 | 成人一级黄色片 | 四虎在线视频 | 欧美整片sss | 免费看毛片网站 | 国产精品毛片一区二区在线看 | 欧美精品999| 麻豆影视在线播放 | 亚州av一区 | 久久久久久久久久久精 | 国产九色视频在线观看 | 亚洲精品一区二区三区新线路 | 亚洲另类xxxx | 天天av天天 | 中文字幕久久网 | 福利视频网址 | 亚洲精品xxxx | 日韩av中文字幕在线免费观看 | 亚洲高清在线精品 | 亚洲美女视频在线 | 色婷婷播放 | 怡红院av久久久久久久 | 国产免费成人av | 国产精品久久久久久久av大片 | 国内精品免费 | 免费看三级黄色片 | 四虎在线免费观看 | 81国产精品久久久久久久久久 | 日韩精品免费一区二区三区 | www.久草.com | 最近中文字幕免费av | 国产在线精品二区 | 99久久久久成人国产免费 | 国产精品9999 | 成人va视频 | 成人午夜精品福利免费 | 亚洲精品一区二区三区四区高清 | 99九九热只有国产精品 | 精品9999 | 黄色影院在线免费观看 | 国产在线播放一区二区三区 | 国产午夜精品一区二区三区嫩草 | 国产精品av久久久久久无 | 蜜桃av观看 | 日本三级人妇 | 在线看片一区 | 国产精品久久久久久久久久久免费 | 99福利影院 | 亚洲精品国产精品国 | 国产日韩欧美在线 | 狠狠搞,com | 精品一区二区久久久久久久网站 | 精品国产免费观看 | 中文字幕亚洲国产 | 国产精品18毛片一区二区 | 福利片免费看 | 青草视频在线免费 | 精品9999 | 亚洲无在线 | 看国产黄色片 | 亚洲成人精品久久 | 日韩欧美网站 | 免费人成在线观看 | 久久婷婷国产色一区二区三区 | 色综合天天狠狠 | 日韩精品一区二区三区水蜜桃 | 日本久久久久久 | 黄色软件大全网站 | 狠狠综合久久 | 久久在线视频在线 | 亚洲欧洲精品一区二区 | 99视频这里有精品 | 成人在线网站观看 | av电影在线观看完整版一区二区 | 91九色在线观看视频 | 波多野结衣电影一区二区三区 | 久久精品亚洲综合专区 | 国产精品午夜在线观看 | 久草在线久草在线2 | 国产小视频福利在线 | 国产精品专区在线观看 | 97超视频在线观看 | 精品99免费视频 | 激情校园亚洲 | 九九九九九国产 | 成人在线播放免费观看 | 国产高清在线视频 | 美女视频免费一区二区 | 欧美久久久久久久久久 | 开心激情婷婷 | 久久久三级视频 | 狠狠躁夜夜av | 日日夜夜网 | 狠狠色丁香婷婷综合最新地址 | 精品一区精品二区高清 | 伊人午夜视频 | 亚洲热视频 | 成人av免费在线观看 | 精品电影一区 | 免费人成在线观看网站 | av片在线观看 | 亚洲精品男人天堂 | 精品久久一区 | 97精品国产91久久久久久久 | 国产精品高清在线观看 | 久久精品99北条麻妃 | 91人人爽久久涩噜噜噜 | 国内精品久久久久影院优 | 久久香蕉国产 | 国产精品免费麻豆入口 | 久久美女高清视频 | 日韩aⅴ视频 | 欧美极品一区二区三区 | 国产精品孕妇 | 免费在线观看av的网站 | 国产aaa大片 | 久久y | 亚洲精品国产精品国自产观看浪潮 | 亚洲午夜在线视频 | 日韩欧美有码在线 | 探花视频在线观看免费 | 视频在线观看亚洲 | 最近中文国产在线视频 | 色婷婷久久久 | 久久国产精品视频观看 | 国产一级在线 | 免费亚洲精品 | 91视频88av| 西西44人体做爰大胆视频 | 91看片网址| 中文字幕免费一区 | 日韩在线免费观看视频 | 日本爽妇网 | 久久久久久久影院 | 香蕉视频免费看 | 亚洲精品成人av在线 | 狠狠色伊人亚洲综合成人 | 自拍超碰在线 | 国产精品专区在线观看 | 国产视频在线一区二区 | 久草在线看片 | 国内视频1区 | 在线观看中文字幕亚洲 | 超碰97人| 亚洲精品在线播放视频 | 成人h在线播放 | 青青色影院| 国产在线观看你懂得 | 亚洲 欧美 日韩 综合 | 91亚洲精品久久久中文字幕 | 欧美一级欧美一级 | 天天干天天干 | 久久国产免费看 | 国产一区二区在线影院 | 美女网站在线观看 | 综合国产在线 | 国产精品一区二区免费在线观看 | 欧美成人精品在线 | 99激情网 | 久久精品一二三区白丝高潮 | 国产精品久久av | 天天爽天天碰狠狠添 | 91视频下载| 91女人18片女毛片60分钟 | 日韩r级在线 | 久久视频网 | 亚洲午夜精品久久久 | 国产高清免费 | 91在线视频免费播放 | 丁香狠狠 | 国产午夜麻豆影院在线观看 | 国产精品亚洲片夜色在线 | 奇米网777 | 在线日本看片免费人成视久网 | 成人黄色大片在线免费观看 | 国产成人三级一区二区在线观看一 | 久久99精品久久久久久 | 欧美久久久久久久久中文字幕 | 久久久黄色免费网站 | 免费在线黄网 | 伊人色综合网 | 久久人人精品 | 日韩高清在线不卡 | 九九99靖品| 天天操天天添天天吹 | 国产精品色在线 | 国产精品原创av片国产免费 | 五月天婷亚洲天综合网鲁鲁鲁 | 亚州欧美精品 | 免费在线观看黄色网 | 国产玖玖在线 | 国产永久免费高清在线观看视频 | 韩国精品福利一区二区三区 | 涩涩网站在线播放 | 中文字幕在线看视频 | 91一区啪爱嗯打偷拍欧美 | 一区二区不卡 | 久久精品一二区 | 欧美另类调教 | 久久天天躁夜夜躁狠狠85麻豆 | 亚洲人人爱 | 天天操夜夜拍 | 色吊丝av中文字幕 | 精品日本视频 | 国产高清在线一区 | 婷婷六月综合亚洲 | 深爱激情亚洲 | 成人在线黄色电影 | www.国产毛片| 中文字幕a∨在线乱码免费看 | 成人影视免费看 | 国产精品一区二区白浆 | 玖玖在线精品 | 高清视频一区二区三区 | 久久精品视频在线播放 | 亚洲综合在线观看视频 | 91成熟丰满女人少妇 | 久久蜜臀一区二区三区av | 99在线看| 日本韩国精品在线 | 久久精品老司机 | 成人中文字幕+乱码+中文字幕 | av在线色| 久久激情五月丁香伊人 | 久草网站在线 | 午夜手机看片 | 精品视频资源站 | 久久久久女教师免费一区 | 婷婷九月激情 | 国产高清免费av | 天天干天天操天天拍 | 精品久久久久一区二区国产 | www五月天 | 婷婷综合 | 国产精品18毛片一区二区 | 狠狠躁天天躁 | 三级黄色在线观看 | 色狠狠婷婷| 国产精品成人av在线 | 激情五月婷婷综合网 | 免费观看成年人视频 | 在线影院 国内精品 | 精品国偷自产在线 | 欧美性免费 | av丁香花 | 免费av黄色 | 在线观看色网 | 激情五月av| 精品久久久久久久久中文字幕 | 四虎成人免费观看 | 精品中文字幕在线观看 | 天天色天天射天天综合网 | 欧美在线观看视频一区二区三区 | 国产亚洲免费的视频看 | 久久综合九色综合欧美就去吻 | 久久精品999 | 国产精品国产亚洲精品看不卡 | 亚洲精品乱码久久久久久蜜桃91 | 98涩涩国产露脸精品国产网 | 久久人网| 久久成人18免费网站 | 99久久婷婷国产精品综合 | 精品久久91 | 久久久久亚洲天堂 | 狠狠操夜夜 | 中文字幕在线观看一区二区三区 | 国产精品久久久久婷婷 |