3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

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

java

Java字节码增强探秘

發布時間:2023/12/20 java 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java字节码增强探秘 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.字節碼

1.1 什么是字節碼?

Java之所以可以“一次編譯,到處運行”,一是因為JVM針對各種操作系統、平臺都進行了定制,二是因為無論在什么平臺,都可以編譯生成固定格式的字節碼(.class文件)供JVM使用。因此,也可以看出字節碼對于Java生態的重要性。之所以被稱之為字節碼,是因為字節碼文件由十六進制值組成,而JVM以兩個十六進制值為一組,即以字節為單位進行讀取。在Java中一般是用javac命令編譯源代碼為字節碼文件,一個.java文件從編譯到運行的示例如圖1所示。

對于開發人員,了解字節碼可以更準確、直觀地理解Java語言中更深層次的東西,比如通過字節碼,可以很直觀地看到Volatile關鍵字如何在字節碼上生效。另外,字節碼增強技術在Spring AOP、各種ORM框架、熱部署中的應用屢見不鮮,深入理解其原理對于我們來說大有裨益。除此之外,由于JVM規范的存在,只要最終可以生成符合規范的字節碼就可以在JVM上運行,因此這就給了各種運行在JVM上的語言(如Scala、Groovy、Kotlin)一種契機,可以擴展Java所沒有的特性或者實現各種語法糖。理解字節碼后再學習這些語言,可以“逆流而上”,從字節碼視角看它的設計思路,學習起來也“易如反掌”。

本文重點著眼于字節碼增強技術,從字節碼開始逐層向上,由JVM字節碼操作集合到Java中操作字節碼的框架,再到我們熟悉的各類框架原理及應用,也都會一一進行介紹。

1.2 字節碼結構

.java文件通過javac編譯后將得到一個.class文件,比如編寫一個簡單的ByteCodeDemo類,如下圖2的左側部分:

編譯后生成ByteCodeDemo.class文件,打開后是一堆十六進制數,按字節為單位進行分割后展示如圖2右側部分所示。上文提及過,JVM對于字節碼是有規范要求的,那么看似雜亂的十六進制符合什么結構呢?JVM規范要求每一個字節碼文件都要由十部分按照固定的順序組成,整體結構如圖3所示。接下來我們將一一介紹這十部分:

(1) 魔數(Magic Number)

所有的.class文件的前四個字節都是魔數,魔數的固定值為:0xCAFEBABE。魔數放在文件開頭,JVM可以根據文件的開頭來判斷這個文件是否可能是一個.class文件,如果是,才會繼續進行之后的操作。

有趣的是,魔數的固定值是Java之父James Gosling制定的,為CafeBabe(咖啡寶貝),而Java的圖標為一杯咖啡。

(2) 版本號

版本號為魔數之后的4個字節,前兩個字節表示次版本號(Minor Version),后兩個字節表示主版本號(Major Version)。上圖2中版本號為“00 00 00 34”,次版本號轉化為十進制為0,主版本號轉化為十進制為52,在Oracle官網中查詢序號52對應的主版本號為1.8,所以編譯該文件的Java版本號為1.8.0。

(3) 常量池(Constant Pool)

緊接著主版本號之后的字節為常量池入口。常量池中存儲兩類常量:字面量與符號引用。字面量為代碼中聲明為Final的常量值,符號引用如類和接口的全局限定名、字段的名稱和描述符、方法的名稱和描述符。常量池整體上分為兩部分:常量池計數器以及常量池數據區,如下圖4所示。

  • 常量池計數器(constant_pool_count):由于常量的數量不固定,所以需要先放置兩個字節來表示常量池容量計數值。圖2中示例代碼的字節碼前10個字節如下圖5所示,將十六進制的24轉化為十進制值為36,排除掉下標“0”,也就是說,這個類文件中共有35個常量。

  • 常量池數據區:數據區是由(constant_pool_count-1)個cp_info結構組成,一個cp_info結構對應一個常量。在字節碼中共有14種類型的cp_info(如下圖6所示),每種類型的結構都是固定的。

具體以CONSTANT_utf8_info為例,它的結構如下圖7左側所示。首先一個字節“tag”,它的值取自上圖6中對應項的Tag,由于它的類型是utf8_info,所以值為“01”。接下來兩個字節標識該字符串的長度Length,然后Length個字節為這個字符串具體的值。從圖2中的字節碼摘取一個cp_info結構,如下圖7右側所示。將它翻譯過來后,其含義為:該常量類型為utf8字符串,長度為一字節,數據為“a”。

其他類型的cp_info結構在本文不再贅述,整體結構大同小異,都是先通過Tag來標識類型,然后后續n個字節來描述長度和(或)數據。先知其所以然,以后可以通過javap -verbose ByteCodeDemo命令,查看JVM反編譯后的完整常量池,如下圖8所示??梢钥吹椒淳幾g結果將每一個cp_info結構的類型和值都很明確地呈現了出來。

(4) 訪問標志

常量池結束之后的兩個字節,描述該Class是類還是接口,以及是否被Public、Abstract、Final等修飾符修飾。JVM規范規定了如下圖9的訪問標志(Access_Flag)。需要注意的是,JVM并沒有窮舉所有的訪問標志,而是使用按位或操作來進行描述的,比如某個類的修飾符為Public Final,則對應的訪問修飾符的值為ACC_PUBLIC | ACC_FINAL,即0x0001 | 0x0010=0x0011。

(5) 當前類名

訪問標志后的兩個字節,描述的是當前類的全限定名。這兩個字節保存的值為常量池中的索引值,根據索引值就能在常量池中找到這個類的全限定名。

(6) 父類名稱

當前類名后的兩個字節,描述父類的全限定名,同上,保存的也是常量池中的索引值。

(7) 接口信息

父類名稱后為兩字節的接口計數器,描述了該類或父類實現的接口數量。緊接著的n個字節是所有接口名稱的字符串常量的索引值。

(8) 字段表

字段表用于描述類和接口中聲明的變量,包含類級別的變量以及實例變量,但是不包含方法內部聲明的局部變量。字段表也分為兩部分,第一部分為兩個字節,描述字段個數;第二部分是每個字段的詳細信息fields_info。字段表結構如下圖所示:

以圖2中字節碼的字段表為例,如下圖11所示。其中字段的訪問標志查圖9,0002對應為Private。通過索引下標在圖8中常量池分別得到字段名為“a”,描述符為“I”(代表int)。綜上,就可以唯一確定出一個類中聲明的變量private int a。

(9)方法表

字段表結束后為方法表,方法表也是由兩部分組成,第一部分為兩個字節描述方法的個數;第二部分為每個方法的詳細信息。方法的詳細信息較為復雜,包括方法的訪問標志、方法名、方法的描述符以及方法的屬性,如下圖所示:

方法的權限修飾符依然可以通過圖9的值查詢得到,方法名和方法的描述符都是常量池中的索引值,可以通過索引值在常量池中找到。而“方法的屬性”這一部分較為復雜,直接借助javap -verbose將其反編譯為人可以讀懂的信息進行解讀,如圖13所示??梢钥吹綄傩灾邪ㄒ韵氯齻€部分:

  • “Code區”:源代碼對應的JVM指令操作碼,在進行字節碼增強時重點操作的就是“Code區”這一部分。
  • “LineNumberTable”:行號表,將Code區的操作碼和源代碼中的行號對應,Debug時會起到作用(源代碼走一行,需要走多少個JVM指令操作碼)。
  • “LocalVariableTable”:本地變量表,包含This和局部變量,之所以可以在每一個方法內部都可以調用This,是因為JVM將This作為每一個方法的第一個參數隱式進行傳入。當然,這是針對非Static方法而言。

(10)附加屬性表

字節碼的最后一部分,該項存放了在該文件中類或接口所定義屬性的基本信息。

1.3 字節碼操作集合

在上圖13中,Code區的紅色編號0~17,就是.java中的方法源代碼編譯后讓JVM真正執行的操作碼。為了幫助人們理解,反編譯后看到的是十六進制操作碼所對應的助記符,十六進制值操作碼與助記符的對應關系,以及每一個操作碼的用處可以查看Oracle官方文檔進行了解,在需要用到時進行查閱即可。比如上圖中第一個助記符為iconst_2,對應到圖2中的字節碼為0x05,用處是將int值2壓入操作數棧中。以此類推,對0~17的助記符理解后,就是完整的add()方法的實現。

1.4 操作數棧和字節碼

JVM的指令集是基于棧而不是寄存器,基于??梢跃邆浜芎玫目缙脚_性(因為寄存器指令集往往和硬件掛鉤),但缺點在于,要完成同樣的操作,基于棧的實現需要更多指令才能完成(因為棧只是一個FILO結構,需要頻繁壓棧出棧)。另外,由于棧是在內存實現的,而寄存器是在CPU的高速緩存區,相較而言,基于棧的速度要慢很多,這也是為了跨平臺性而做出的犧牲。

我們在上文所說的操作碼或者操作集合,其實控制的就是這個JVM的操作數棧。為了更直觀地感受操作碼是如何控制操作數棧的,以及理解常量池、變量表的作用,將add()方法的對操作數棧的操作制作為GIF,如下圖14所示,圖中僅截取了常量池中被引用的部分,以指令iconst_2開始到ireturn結束,與圖13中Code區0~17的指令一一對應:

1.5 查看字節碼工具

如果每次查看反編譯后的字節碼都使用javap命令的話,好非常繁瑣。這里推薦一個Idea插件:jclasslib。使用效果如圖15所示,代碼編譯后在菜單欄"View"中選擇"Show Bytecode With jclasslib",可以很直觀地看到當前字節碼文件的類信息、常量池、方法區等信息。

2. 字節碼增強

在上文中,著重介紹了字節碼的結構,這為我們了解字節碼增強技術的實現打下了基礎。字節碼增強技術就是一類對現有字節碼進行修改或者動態生成全新字節碼文件的技術。接下來,我們將從最直接操縱字節碼的實現方式開始深入進行剖析。

2.1 ASM

對于需要手動操縱字節碼的需求,可以使用ASM,它可以直接生產 .class字節碼文件,也可以在類被加載入JVM之前動態修改類行為(如下圖17所示)。ASM的應用場景有AOP(Cglib就是基于ASM)、熱部署、修改其他jar包中的類等。當然,涉及到如此底層的步驟,實現起來也比較麻煩。接下來,本文將介紹ASM的兩種API,并用ASM來實現一個比較粗糙的AOP。但在此之前,為了讓大家更快地理解ASM的處理流程,強烈建議讀者先對訪問者模式進行了解。簡單來說,訪問者模式主要用于修改或操作一些數據結構比較穩定的數據,而通過第一章,我們知道字節碼文件的結構是由JVM固定的,所以很適合利用訪問者模式對字節碼文件進行修改。

2.1.1 ASM API

2.1.1.1 核心API

ASM Core API可以類比解析XML文件中的SAX方式,不需要把這個類的整個結構讀取進來,就可以用流式的方法來處理字節碼文件。好處是非常節約內存,但是編程難度較大。然而出于性能考慮,一般情況下編程都使用Core API。在Core API中有以下幾個關鍵類:

  • ClassReader:用于讀取已經編譯好的.class文件。
  • ClassWriter:用于重新構建編譯后的類,如修改類名、屬性以及方法,也可以生成新的類的字節碼文件。
  • 各種Visitor類:如上所述,CoreAPI根據字節碼從上到下依次處理,對于字節碼文件中不同的區域有不同的Visitor,比如用于訪問方法的MethodVisitor、用于訪問類變量的FieldVisitor、用于訪問注解的AnnotationVisitor等。為了實現AOP,重點要使用的是MethodVisitor。

2.1.1.2 樹形API

ASM Tree API可以類比解析XML文件中的DOM方式,把整個類的結構讀取到內存中,缺點是消耗內存多,但是編程比較簡單。TreeApi不同于CoreAPI,TreeAPI通過各種Node類來映射字節碼的各個區域,類比DOM節點,就可以很好地理解這種編程方式。

2.1.2 直接利用ASM實現AOP

利用ASM的CoreAPI來增強類。這里不糾結于AOP的專業名詞如切片、通知,只實現在方法調用前、后增加邏輯,通俗易懂且方便理解。首先定義需要被增強的Base類:其中只包含一個process()方法,方法內輸出一行“process”。增強后,我們期望的是,方法執行前輸出“start”,之后輸出"end"。

public class Base {public void process(){System.out.println("process");} }

為了利用ASM實現AOP,需要定義兩個類:一個是MyClassVisitor類,用于對字節碼的visit以及修改;另一個是Generator類,在這個類中定義ClassReader和ClassWriter,其中的邏輯是,classReader讀取字節碼,然后交給MyClassVisitor類處理,處理完成后由ClassWriter寫字節碼并將舊的字節碼替換掉。Generator類較簡單,我們先看一下它的實現,如下所示,然后重點解釋MyClassVisitor類。

import org.objectweb.asm.ClassReader; import org.objectweb.asm.ClassVisitor; import org.objectweb.asm.ClassWriter;public class Generator {public static void main(String[] args) throws Exception {//讀取ClassReader classReader = new ClassReader("meituan/bytecode/asm/Base");ClassWriter classWriter = new ClassWriter(ClassWriter.COMPUTE_MAXS);//處理ClassVisitor classVisitor = new MyClassVisitor(classWriter);classReader.accept(classVisitor, ClassReader.SKIP_DEBUG);byte[] data = classWriter.toByteArray();//輸出File f = new File("operation-server/target/classes/meituan/bytecode/asm/Base.class");FileOutputStream fout = new FileOutputStream(f);fout.write(data);fout.close();System.out.println("now generator cc success!!!!!");} }

MyClassVisitor繼承自ClassVisitor,用于對字節碼的觀察。它還包含一個內部類MyMethodVisitor,繼承自MethodVisitor用于對類內方法的觀察,它的整體代碼如下:

import org.objectweb.asm.ClassVisitor; import org.objectweb.asm.MethodVisitor; import org.objectweb.asm.Opcodes;public class MyClassVisitor extends ClassVisitor implements Opcodes {public MyClassVisitor(ClassVisitor cv) {super(ASM5, cv);}@Overridepublic void visit(int version, int access, String name, String signature,String superName, String[] interfaces) {cv.visit(version, access, name, signature, superName, interfaces);}@Overridepublic MethodVisitor visitMethod(int access, String name, String desc, String signature, String[] exceptions) {MethodVisitor mv = cv.visitMethod(access, name, desc, signature,exceptions);//Base類中有兩個方法:無參構造以及process方法,這里不增強構造方法if (!name.equals("<init>") && mv != null) {mv = new MyMethodVisitor(mv);}return mv;}class MyMethodVisitor extends MethodVisitor implements Opcodes {public MyMethodVisitor(MethodVisitor mv) {super(Opcodes.ASM5, mv);}@Overridepublic void visitCode() {super.visitCode();mv.visitFieldInsn(GETSTATIC, "java/lang/System", "out", "Ljava/io/PrintStream;");mv.visitLdcInsn("start");mv.visitMethodInsn(INVOKEVIRTUAL, "java/io/PrintStream", "println", "(Ljava/lang/String;)V", false);}@Overridepublic void visitInsn(int opcode) {if ((opcode >= Opcodes.IRETURN && opcode <= Opcodes.RETURN)|| opcode == Opcodes.ATHROW) {//方法在返回之前,打印"end"mv.visitFieldInsn(GETSTATIC, "java/lang/System", "out", "Ljava/io/PrintStream;");mv.visitLdcInsn("end");mv.visitMethodInsn(INVOKEVIRTUAL, "java/io/PrintStream", "println", "(Ljava/lang/String;)V", false);}mv.visitInsn(opcode);}} }

利用這個類就可以實現對字節碼的修改。詳細解讀其中的代碼,對字節碼做修改的步驟是:

  • 首先通過MyClassVisitor類中的visitMethod方法,判斷當前字節碼讀到哪一個方法了。跳過構造方法""后,將需要被增強的方法交給內部類MyMethodVisitor來進行處理。
  • 接下來,進入內部類MyMethodVisitor中的visitCode方法,它會在ASM開始訪問某一個方法的Code區時被調用,重寫visitCode方法,將AOP中的前置邏輯就放在這里。
  • MyMethodVisitor繼續讀取字節碼指令,每當ASM訪問到無參數指令時,都會調用MyMethodVisitor中的visitInsn方法。我們判斷了當前指令是否為無參數的“return”指令,如果是就在它的前面添加一些指令,也就是將AOP的后置邏輯放在該方法中。
  • 綜上,重寫MyMethodVisitor中的兩個方法,就可以實現AOP了,而重寫方法時就需要用ASM的寫法,手動寫入或者修改字節碼。通過調用methodVisitor的visitXXXXInsn()方法就可以實現字節碼的插入,XXXX對應相應的操作碼助記符類型,比如mv.visitLdcInsn(“end”)對應的操作碼就是ldc “end”,即將字符串“end”壓入棧。

完成這兩個visitor類后,運行Generator中的main方法完成對Base類的字節碼增強,增強后的結果可以在編譯后的target文件夾中找到Base.class文件進行查看,可以看到反編譯后的代碼已經改變了(如圖18左側所示)。然后寫一個測試類MyTest,在其中new Base(),并調用base.process()方法,可以看到下圖右側所示的AOP實現效果:

2.1.3 ASM工具

利用ASM手寫字節碼時,需要利用一系列visitXXXXInsn()方法來寫對應的助記符,所以需要先將每一行源代碼轉化為一個個的助記符,然后通過ASM的語法轉換為visitXXXXInsn()這種寫法。第一步將源碼轉化為助記符就已經夠麻煩了,不熟悉字節碼操作集合的話,需要我們將代碼編譯后再反編譯,才能得到源代碼對應的助記符。第二步利用ASM寫字節碼時,如何傳參也很令人頭疼。ASM社區也知道這兩個問題,所以提供了工具ASM ByteCode Outline。

安裝后,右鍵選擇“Show Bytecode Outline”,在新標簽頁中選擇“ASMified”這個tab,如圖19所示,就可以看到這個類中的代碼對應的ASM寫法了。圖中上下兩個紅框分別對應AOP中的前置邏輯于后置邏輯,將這兩塊直接復制到visitor中的visitMethod()以及visitInsn()方法中,就可以了。

2.2 Javassist

ASM是在指令層次上操作字節碼的,閱讀上文后,我們的直觀感受是在指令層次上操作字節碼的框架實現起來比較晦澀。故除此之外,我們再簡單介紹另外一類框架:強調源代碼層次操作字節碼的框架Javassist。

利用Javassist實現字節碼增強時,可以無須關注字節碼刻板的結構,其優點就在于編程簡單。直接使用java編碼的形式,而不需要了解虛擬機指令,就能動態改變類的結構或者動態生成類。其中最重要的是ClassPool、CtClass、CtMethod、CtField這四個類:

  • CtClass(compile-time class):編譯時類信息,它是一個class文件在代碼中的抽象表現形式,可以通過一個類的全限定名來獲取一個CtClass對象,用來表示這個類文件。
  • ClassPool:從開發視角來看,ClassPool是一張保存CtClass信息的HashTable,key為類名,value為類名對應的CtClass對象。當我們需要對某個類進行修改時,就是通過pool.getCtClass(“className”)方法從pool中獲取到相應的CtClass。
  • CtMethod、CtField:這兩個比較好理解,對應的是類中的方法和屬性。

了解這四個類后,我們可以寫一個小Demo來展示Javassist簡單、快速的特點。我們依然是對Base中的process()方法做增強,在方法調用前后分別輸出"start"和"end",實現代碼如下。我們需要做的就是從pool中獲取到相應的CtClass對象和其中的方法,然后執行method.insertBefore和insertAfter方法,參數為要插入的Java代碼,再以字符串的形式傳入即可,實現起來也極為簡單。

import com.meituan.mtrace.agent.javassist.*;public class JavassistTest {public static void main(String[] args) throws NotFoundException, CannotCompileException, IllegalAccessException, InstantiationException, IOException {ClassPool cp = ClassPool.getDefault();CtClass cc = cp.get("meituan.bytecode.javassist.Base");CtMethod m = cc.getDeclaredMethod("process");m.insertBefore("{ System.out.println(\"start\"); }");m.insertAfter("{ System.out.println(\"end\"); }");Class c = cc.toClass();cc.writeFile("/Users/zen/projects");Base h = (Base)c.newInstance();h.process();} }

3. 運行時類的重載

3.1 問題引出

上一章重點介紹了兩種不同類型的字節碼操作框架,且都利用它們實現了較為粗糙的AOP。其實,為了方便大家理解字節碼增強技術,在上文中我們避重就輕將ASM實現AOP的過程分為了兩個main方法:第一個是利用MyClassVisitor對已編譯好的class文件進行修改,第二個是new對象并調用。這期間并不涉及到JVM運行時對類的重加載,而是在第一個main方法中,通過ASM對已編譯類的字節碼進行替換,在第二個main方法中,直接使用已替換好的新類信息。另外在Javassist的實現中,我們也只加載了一次Base類,也不涉及到運行時重加載類。

如果我們在一個JVM中,先加載了一個類,然后又對其進行字節碼增強并重新加載會發生什么呢?模擬這種情況,只需要我們在上文中Javassist的Demo中main()方法的第一行添加Base b=new Base(),即在增強前就先讓JVM加載Base類,然后在執行到c.toClass()方法時會拋出錯誤,如下圖20所示。跟進c.toClass()方法中,我們會發現它是在最后調用了ClassLoader的native方法defineClass()時報錯。也就是說,JVM是不允許在運行時動態重載一個類的。

顯然,如果只能在類加載前對類進行強化,那字節碼增強技術的使用場景就變得很窄了。我們期望的效果是:在一個持續運行并已經加載了所有類的JVM中,還能利用字節碼增強技術對其中的類行為做替換并重新加載。為了模擬這種情況,我們將Base類做改寫,在其中編寫main方法,每五秒調用一次process()方法,在process()方法中輸出一行“process”。

我們的目的就是,在JVM運行中的時候,將process()方法做替換,在其前后分別打印“start”和“end”。也就是在運行中時,每五秒打印的內容由"process"變為打印"start process end"。那如何解決JVM不允許運行時重加載類信息的問題呢?為了達到這個目的,我們接下來一一來介紹需要借助的Java類庫。

import java.lang.management.ManagementFactory;public class Base {public static void main(String[] args) {String name = ManagementFactory.getRuntimeMXBean().getName();String s = name.split("@")[0];//打印當前PidSystem.out.println("pid:"+s);while (true) {try {Thread.sleep(5000L);} catch (Exception e) {break;}process();}}public static void process() {System.out.println("process");} }

3.2 Instrument

instrument是JVM提供的一個可以修改已加載類的類庫,專門為Java語言編寫的插樁服務提供支持。它需要依賴JVMTI的Attach API機制實現,JVMTI這一部分,我們將在下一小節進行介紹。在JDK 1.6以前,instrument只能在JVM剛啟動開始加載類時生效,而在JDK 1.6之后,instrument支持了在運行時對類定義的修改。要使用instrument的類修改功能,我們需要實現它提供的ClassFileTransformer接口,定義一個類文件轉換器。接口中的transform()方法會在類文件被加載時調用,而在transform方法里,我們可以利用上文中的ASM或Javassist對傳入的字節碼進行改寫或替換,生成新的字節碼數組后返回。

我們定義一個實現了ClassFileTransformer接口的類TestTransformer,依然在其中利用Javassist對Base類中的process()方法進行增強,在前后分別打印“start”和“end”,代碼如下:

import java.lang.instrument.ClassFileTransformer;public class TestTransformer implements ClassFileTransformer {@Overridepublic byte[] transform(ClassLoader loader, String className, Class<?> classBeingRedefined, ProtectionDomain protectionDomain, byte[] classfileBuffer) {System.out.println("Transforming " + className);try {ClassPool cp = ClassPool.getDefault();CtClass cc = cp.get("meituan.bytecode.jvmti.Base");CtMethod m = cc.getDeclaredMethod("process");m.insertBefore("{ System.out.println(\"start\"); }");m.insertAfter("{ System.out.println(\"end\"); }");return cc.toBytecode();} catch (Exception e) {e.printStackTrace();}return null;} }

現在有了Transformer,那么它要如何注入到正在運行的JVM呢?還需要定義一個Agent,借助Agent的能力將Instrument注入到JVM中。我們將在下一小節介紹Agent,現在要介紹的是Agent中用到的另一個類Instrumentation。在JDK 1.6之后,Instrumentation可以做啟動后的Instrument、本地代碼(Native Code)的Instrument,以及動態改變Classpath等等。我們可以向Instrumentation中添加上文中定義的Transformer,并指定要被重加載的類,代碼如下所示。這樣,當Agent被Attach到一個JVM中時,就會執行類字節碼替換并重載入JVM的操作。

import java.lang.instrument.Instrumentation;public class TestAgent {public static void agentmain(String args, Instrumentation inst) {//指定我們自己定義的Transformer,在其中利用Javassist做字節碼替換inst.addTransformer(new TestTransformer(), true);try {//重定義類并載入新的字節碼inst.retransformClasses(Base.class);System.out.println("Agent Load Done.");} catch (Exception e) {System.out.println("agent load failed!");}} }

3.3 JVMTI & Agent & Attach API

上一小節中,我們給出了Agent類的代碼,追根溯源需要先介紹JPDA(Java Platform Debugger Architecture)。如果JVM啟動時開啟了JPDA,那么類是允許被重新加載的。在這種情況下,已被加載的舊版本類信息可以被卸載,然后重新加載新版本的類。正如JDPA名稱中的Debugger,JDPA其實是一套用于調試Java程序的標準,任何JDK都必須實現該標準。

JPDA定義了一整套完整的體系,它將調試體系分為三部分,并規定了三者之間的通信接口。三部分由低到高分別是Java 虛擬機工具接口(JVMTI),Java 調試協議(JDWP)以及 Java 調試接口(JDI),三者之間的關系如下圖所示:

現在回到正題,我們可以借助JVMTI的一部分能力,幫助動態重載類信息。JVM TI(JVM TOOL INTERFACE,JVM工具接口)是JVM提供的一套對JVM進行操作的工具接口。通過JVMTI,可以實現對JVM的多種操作,它通過接口注冊各種事件勾子,在JVM事件觸發時,同時觸發預定義的勾子,以實現對各個JVM事件的響應,事件包括類文件加載、異常產生與捕獲、線程啟動和結束、進入和退出臨界區、成員變量修改、GC開始和結束、方法調用進入和退出、臨界區競爭與等待、VM啟動與退出等等。

而Agent就是JVMTI的一種實現,Agent有兩種啟動方式,一是隨Java進程啟動而啟動,經常見到的java -agentlib就是這種方式;二是運行時載入,通過attach API,將模塊(jar包)動態地Attach到指定進程id的Java進程內。

Attach API 的作用是提供JVM進程間通信的能力,比如說我們為了讓另外一個JVM進程把線上服務的線程Dump出來,會運行jstack或jmap的進程,并傳遞pid的參數,告訴它要對哪個進程進行線程Dump,這就是Attach API做的事情。在下面,我們將通過Attach API的loadAgent()方法,將打包好的Agent jar包動態Attach到目標JVM上。具體實現起來的步驟如下:

  • 定義Agent,并在其中實現AgentMain方法,如上一小節中定義的代碼塊7中的TestAgent類;
  • 然后將TestAgent類打成一個包含MANIFEST.MF的jar包,其中MANIFEST.MF文件中將Agent-Class屬性指定為TestAgent的全限定名,如下圖所示;

  • 最后利用Attach API,將我們打包好的jar包Attach到指定的JVM pid上,代碼如下:
import com.sun.tools.attach.VirtualMachine;public class Attacher {public static void main(String[] args) throws AttachNotSupportedException, IOException, AgentLoadException, AgentInitializationException {// 傳入目標 JVM pidVirtualMachine vm = VirtualMachine.attach("39333"); vm.loadAgent("/Users/zen/operation_server_jar/operation-server.jar");} }
  • 由于在MANIFEST.MF中指定了Agent-Class,所以在Attach后,目標JVM在運行時會走到TestAgent類中定義的agentmain()方法,而在這個方法中,我們利用Instrumentation,將指定類的字節碼通過定義的類轉化器TestTransformer做了Base類的字節碼替換(通過javassist),并完成了類的重新加載。由此,我們達成了“在JVM運行時,改變類的字節碼并重新載入類信息”的目的。

以下為運行時重新載入類的效果:先運行Base中的main()方法,啟動一個JVM,可以在控制臺看到每隔五秒輸出一次"process"。接著執行Attacher中的main()方法,并將上一個JVM的pid傳入。此時回到上一個main()方法的控制臺,可以看到現在每隔五秒輸出"process"前后會分別輸出"start"和"end",也就是說完成了運行時的字節碼增強,并重新載入了這個類。

3.4 使用場景

至此,字節碼增強技術的可使用范圍就不再局限于JVM加載類前了。通過上述幾個類庫,我們可以在運行時對JVM中的類進行修改并重載了。通過這種手段,可以做的事情就變得很多了:

  • 熱部署:不部署服務而對線上服務做修改,可以做打點、增加日志等操作。
  • Mock:測試時候對某些服務做Mock。
  • 性能診斷工具:比如bTrace就是利用Instrument,實現無侵入地跟蹤一個正在運行的JVM,監控到類和方法級別的狀態信息。

4. 總結

字節碼增強技術相當于是一把打開運行時JVM的鑰匙,利用它可以動態地對運行中的程序做修改,也可以跟蹤JVM運行中程序的狀態。此外,我們平時使用的動態代理、AOP也與字節碼增強密切相關,它們實質上還是利用各種手段生成符合規范的字節碼文件。綜上所述,掌握字節碼增強后可以高效地定位并快速修復一些棘手的問題(如線上性能問題、方法出現不可控的出入參需要緊急加日志等問題),也可以在開發中減少冗余代碼,大大提高開發效率。

5. 參考文獻

  • 《ASM4-Guide》
  • Oracle:The class File Format
  • Oracle:The Java Virtual Machine Instruction Set
  • javassist tutorial
  • JVM Tool Interface - Version 1.2

作者簡介

澤恩,美團點評研發工程師。

團隊信息

美團到店住宿業務研發團隊負責美團酒店核心業務系統建設,致力于通過技術踐行“幫大家住得更好”的使命。美團酒店屢次刷新行業記錄,最近12個月酒店預訂間夜量達到3個億,單日入住間夜量峰值突破280萬。團隊的愿景是:建設打造旅游住宿行業一流的技術架構,從質量、安全、效率、性能多角度保障系統高速發展。
美團到店事業群住宿業務研發團隊現誠聘后臺開發工程師/技術專家,歡迎有興趣的同學加入。

總結

以上是生活随笔為你收集整理的Java字节码增强探秘的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国产亚洲精品久久久久久久 | 精品人人妻人人澡人人爽人人 | 亚洲高清偷拍一区二区三区 | 麻豆国产丝袜白领秘书在线观看 | 天天躁日日躁狠狠躁免费麻豆 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 又黄又爽又色的视频 | 2020最新国产自产精品 | 欧美怡红院免费全部视频 | 人妻夜夜爽天天爽三区 | 亚洲va中文字幕无码久久不卡 | 中文字幕人妻无码一夲道 | 秋霞成人午夜鲁丝一区二区三区 | 无人区乱码一区二区三区 | 色窝窝无码一区二区三区色欲 | 色一情一乱一伦一区二区三欧美 | 十八禁视频网站在线观看 | 国产色xx群视频射精 | 乱码av麻豆丝袜熟女系列 | 国产国语老龄妇女a片 | 亚洲s色大片在线观看 | 丰满人妻一区二区三区免费视频 | 一本久道久久综合婷婷五月 | 日本xxxx色视频在线观看免费 | 日日摸夜夜摸狠狠摸婷婷 | 麻豆精品国产精华精华液好用吗 | 中文字幕无码人妻少妇免费 | 国产9 9在线 | 中文 | 精品久久综合1区2区3区激情 | 亚洲国产av美女网站 | 性生交大片免费看l | 久久国产劲爆∧v内射 | 国内精品久久久久久中文字幕 | 国产成人无码av在线影院 | 一个人免费观看的www视频 | 无码精品人妻一区二区三区av | 激情国产av做激情国产爱 | 一本色道久久综合亚洲精品不卡 | 亚洲成a人片在线观看无码3d | 国产美女极度色诱视频www | 亚洲精品中文字幕乱码 | 日产精品高潮呻吟av久久 | 国产av无码专区亚洲a∨毛片 | 国产av一区二区三区最新精品 | a片免费视频在线观看 | 精品日本一区二区三区在线观看 | 中文字幕日产无线码一区 | 精品乱子伦一区二区三区 | 国产精品久久久久影院嫩草 | 未满成年国产在线观看 | 成熟妇人a片免费看网站 | 国产农村妇女高潮大叫 | 色综合久久88色综合天天 | 狠狠亚洲超碰狼人久久 | 国产精品怡红院永久免费 | 欧美自拍另类欧美综合图片区 | 99精品久久毛片a片 | 成人女人看片免费视频放人 | 欧美 丝袜 自拍 制服 另类 | 日本一卡2卡3卡四卡精品网站 | 中文字幕色婷婷在线视频 | 亚洲国产av精品一区二区蜜芽 | 国产女主播喷水视频在线观看 | 99麻豆久久久国产精品免费 | 亚洲欧美日韩综合久久久 | 玩弄人妻少妇500系列视频 | 欧美丰满熟妇xxxx性ppx人交 | 国产麻豆精品精东影业av网站 | 久久99国产综合精品 | 日本一区二区三区免费播放 | 国产三级精品三级男人的天堂 | 水蜜桃色314在线观看 | 麻花豆传媒剧国产免费mv在线 | 牲欲强的熟妇农村老妇女视频 | 性欧美熟妇videofreesex | 欧美日韩一区二区综合 | 免费无码av一区二区 | 精品无人区无码乱码毛片国产 | 国产精品久久久久久久影院 | 国产亚洲精品久久久ai换 | 无码毛片视频一区二区本码 | 四虎国产精品免费久久 | 久久99久久99精品中文字幕 | 天天做天天爱天天爽综合网 | 亚洲精品午夜国产va久久成人 | 亚洲乱码中文字幕在线 | 六月丁香婷婷色狠狠久久 | 日韩视频 中文字幕 视频一区 | 国产欧美熟妇另类久久久 | 国产黄在线观看免费观看不卡 | 成人免费无码大片a毛片 | 久久久久人妻一区精品色欧美 | 亚洲欧洲日本综合aⅴ在线 | 国产精品对白交换视频 | 亚洲成a人一区二区三区 | 一区二区传媒有限公司 | 乱人伦人妻中文字幕无码 | 国产真人无遮挡作爱免费视频 | 在线成人www免费观看视频 | 亚洲 激情 小说 另类 欧美 | 六十路熟妇乱子伦 | 丝袜人妻一区二区三区 | 国产熟女一区二区三区四区五区 | 国产精品va在线播放 | 美女毛片一区二区三区四区 | 黑人巨大精品欧美黑寡妇 | 特大黑人娇小亚洲女 | 高潮毛片无遮挡高清免费视频 | 亚洲熟悉妇女xxx妇女av | 国产亚洲精品久久久久久 | 欧美freesex黑人又粗又大 | 亚洲一区av无码专区在线观看 | 一本色道久久综合狠狠躁 | 欧美日韩色另类综合 | 最新国产乱人伦偷精品免费网站 | 亚洲日韩av一区二区三区四区 | 岛国片人妻三上悠亚 | 性欧美熟妇videofreesex | 亚洲人成无码网www | 日韩人妻少妇一区二区三区 | 高清国产亚洲精品自在久久 | 人妻天天爽夜夜爽一区二区 | 午夜免费福利小电影 | 国产精品无码永久免费888 | 人人超人人超碰超国产 | 欧美xxxxx精品 | 亚洲精品一区二区三区婷婷月 | 成人综合网亚洲伊人 | 国产乱人伦av在线无码 | 中文无码精品a∨在线观看不卡 | 亚洲欧美国产精品专区久久 | 精品国产aⅴ无码一区二区 | 日韩欧美成人免费观看 | 一本大道伊人av久久综合 | 又黄又爽又色的视频 | 熟女少妇人妻中文字幕 | 丰满肥臀大屁股熟妇激情视频 | 亚洲成av人影院在线观看 | 无码人妻精品一区二区三区不卡 | 亚洲综合久久一区二区 | 久久视频在线观看精品 | 久久这里只有精品视频9 | 国产精品久久久久久久影院 | 丰满肥臀大屁股熟妇激情视频 | 成年美女黄网站色大免费视频 | 亚洲爆乳大丰满无码专区 | 丰满人妻一区二区三区免费视频 | 亚洲中文字幕无码一久久区 | 宝宝好涨水快流出来免费视频 | 亚洲区欧美区综合区自拍区 | 任你躁在线精品免费 | 国产精品二区一区二区aⅴ污介绍 | 国产精品对白交换视频 | 夜夜高潮次次欢爽av女 | 国产做国产爱免费视频 | 国语自产偷拍精品视频偷 | 国产精品无码mv在线观看 | 久久精品人人做人人综合 | 精品人妻中文字幕有码在线 | 亚洲成a人片在线观看无码 | 麻豆国产97在线 | 欧洲 | 国产精品嫩草久久久久 | 人人爽人人爽人人片av亚洲 | 国色天香社区在线视频 | 午夜成人1000部免费视频 | 久久久久人妻一区精品色欧美 | 国产欧美熟妇另类久久久 | 真人与拘做受免费视频 | 澳门永久av免费网站 | 丁香花在线影院观看在线播放 | 丁香花在线影院观看在线播放 | 亚洲第一网站男人都懂 | 麻豆蜜桃av蜜臀av色欲av | 亚洲人成人无码网www国产 | 内射白嫩少妇超碰 | 国产精品人人爽人人做我的可爱 | 妺妺窝人体色www在线小说 | 中国大陆精品视频xxxx | 日韩av无码一区二区三区不卡 | 亚洲精品一区二区三区婷婷月 | 欧美第一黄网免费网站 | 国产精品自产拍在线观看 | 国产9 9在线 | 中文 | 成人欧美一区二区三区黑人免费 | 欧美熟妇另类久久久久久不卡 | 在教室伦流澡到高潮hnp视频 | 午夜精品久久久内射近拍高清 | 岛国片人妻三上悠亚 | 精品亚洲韩国一区二区三区 | 欧美国产日韩亚洲中文 | 欧美xxxxx精品 | 福利一区二区三区视频在线观看 | 国语自产偷拍精品视频偷 | 日韩精品乱码av一区二区 | 黑人巨大精品欧美黑寡妇 | 嫩b人妻精品一区二区三区 | 荫蒂添的好舒服视频囗交 | 免费网站看v片在线18禁无码 | 丰满岳乱妇在线观看中字无码 | 爽爽影院免费观看 | 蜜桃无码一区二区三区 | 久久精品女人天堂av免费观看 | 夜夜影院未满十八勿进 | 日韩欧美群交p片內射中文 | 国产真实伦对白全集 | 国产成人综合色在线观看网站 | 国产熟女一区二区三区四区五区 | 欧美自拍另类欧美综合图片区 | 国产精品无码一区二区桃花视频 | 国产精品久久久一区二区三区 | 国产情侣作爱视频免费观看 | 亚洲精品成a人在线观看 | 六月丁香婷婷色狠狠久久 | 爱做久久久久久 | 精品一区二区三区无码免费视频 | 无码精品人妻一区二区三区av | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 无遮挡国产高潮视频免费观看 | 国产熟女一区二区三区四区五区 | 亚洲一区二区三区偷拍女厕 | 国产97在线 | 亚洲 | 狠狠色色综合网站 | 日本饥渴人妻欲求不满 | 丰满岳乱妇在线观看中字无码 | 亚洲综合精品香蕉久久网 | 无码人妻av免费一区二区三区 | 国产性生交xxxxx无码 | 国产成人一区二区三区在线观看 | 在线精品亚洲一区二区 | 国产精品亚洲专区无码不卡 | 俺去俺来也在线www色官网 | 国产麻豆精品一区二区三区v视界 | 国内老熟妇对白xxxxhd | 两性色午夜免费视频 | 爽爽影院免费观看 | 国产精品高潮呻吟av久久 | 国产人妻精品一区二区三区 | 女人被男人躁得好爽免费视频 | 日本饥渴人妻欲求不满 | 99久久精品无码一区二区毛片 | av无码不卡在线观看免费 | 成人无码精品一区二区三区 | 国产情侣作爱视频免费观看 | 欧美成人高清在线播放 | 亚洲成在人网站无码天堂 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 日欧一片内射va在线影院 | 亚洲码国产精品高潮在线 | 大屁股大乳丰满人妻 | 麻豆人妻少妇精品无码专区 | av香港经典三级级 在线 | 国产一区二区三区精品视频 | 亚洲色偷偷男人的天堂 | 天天摸天天透天天添 | 一本大道伊人av久久综合 | 蜜桃av抽搐高潮一区二区 | 老子影院午夜精品无码 | 又紧又大又爽精品一区二区 | 国产成人精品优优av | 亚洲国精产品一二二线 | 国产一区二区三区日韩精品 | 成人精品一区二区三区中文字幕 | 亚洲色www成人永久网址 | 国产成人无码av在线影院 | 国产国语老龄妇女a片 | aa片在线观看视频在线播放 | 国产suv精品一区二区五 | 粗大的内捧猛烈进出视频 | 国产精品国产自线拍免费软件 | 狠狠色丁香久久婷婷综合五月 | 免费无码肉片在线观看 | 国产精品-区区久久久狼 | 少妇的肉体aa片免费 | 国产福利视频一区二区 | 色偷偷人人澡人人爽人人模 | av在线亚洲欧洲日产一区二区 | 98国产精品综合一区二区三区 | 精品国产精品久久一区免费式 | 东京无码熟妇人妻av在线网址 | 正在播放东北夫妻内射 | 久久这里只有精品视频9 | 欧美一区二区三区 | 亚洲乱码国产乱码精品精 | 国产黄在线观看免费观看不卡 | 男人和女人高潮免费网站 | 国产精品.xx视频.xxtv | 成人精品天堂一区二区三区 | 日日天干夜夜狠狠爱 | 国产卡一卡二卡三 | 国产精品va在线播放 | 毛片内射-百度 | 玩弄少妇高潮ⅹxxxyw | 国产肉丝袜在线观看 | 强伦人妻一区二区三区视频18 | 麻豆成人精品国产免费 | 成人免费无码大片a毛片 | 天天躁夜夜躁狠狠是什么心态 | 纯爱无遮挡h肉动漫在线播放 | 美女极度色诱视频国产 | 九九在线中文字幕无码 | 国内丰满熟女出轨videos | 欧美成人高清在线播放 | 久久99国产综合精品 | 国产日产欧产精品精品app | 无人区乱码一区二区三区 | 久久99热只有频精品8 | 国产精品.xx视频.xxtv | 亚洲无人区一区二区三区 | 国产乱人偷精品人妻a片 | 亚洲国产av精品一区二区蜜芽 | 亲嘴扒胸摸屁股激烈网站 | 欧美精品无码一区二区三区 | 狠狠色欧美亚洲狠狠色www | 午夜精品一区二区三区在线观看 | 久久久久久av无码免费看大片 | 中文字幕av伊人av无码av | 精品夜夜澡人妻无码av蜜桃 | 精品人妻中文字幕有码在线 | 国产肉丝袜在线观看 | 色欲综合久久中文字幕网 | √天堂中文官网8在线 | 76少妇精品导航 | 日产国产精品亚洲系列 | 精品人人妻人人澡人人爽人人 | 欧美 亚洲 国产 另类 | 青草视频在线播放 | 日本高清一区免费中文视频 | 国产精品亚洲专区无码不卡 | 日本一区二区三区免费高清 | av无码电影一区二区三区 | 欧美日韩一区二区综合 | 久久精品女人天堂av免费观看 | 亚洲精品午夜无码电影网 | 免费无码肉片在线观看 | 双乳奶水饱满少妇呻吟 | 亚洲 高清 成人 动漫 | 日韩欧美中文字幕在线三区 | 丰满人妻精品国产99aⅴ | 日韩人妻无码一区二区三区久久99 | 国产精品第一国产精品 | 久久国内精品自在自线 | 亚洲午夜福利在线观看 | 人妻插b视频一区二区三区 | 日韩无套无码精品 | 午夜精品一区二区三区在线观看 | 国产国语老龄妇女a片 | 真人与拘做受免费视频 | 精品国产乱码久久久久乱码 | 欧美熟妇另类久久久久久不卡 | 国产69精品久久久久app下载 | 国产suv精品一区二区五 | 精品少妇爆乳无码av无码专区 | 亚洲国产欧美日韩精品一区二区三区 | 激情爆乳一区二区三区 | v一区无码内射国产 | 亚洲成av人片天堂网无码】 | 玩弄少妇高潮ⅹxxxyw | 极品尤物被啪到呻吟喷水 | 国产熟女一区二区三区四区五区 | 欧美刺激性大交 | 激情国产av做激情国产爱 | 狠狠色丁香久久婷婷综合五月 | 中文字幕av无码一区二区三区电影 | 日本精品人妻无码免费大全 | 久久亚洲日韩精品一区二区三区 | www国产亚洲精品久久久日本 | 无码av岛国片在线播放 | 久久久久99精品成人片 | 清纯唯美经典一区二区 | 日韩欧美群交p片內射中文 | 人妻夜夜爽天天爽三区 | 妺妺窝人体色www在线小说 | 精品一区二区三区无码免费视频 | 人人爽人人爽人人片av亚洲 | 少妇人妻av毛片在线看 | 亚洲爆乳大丰满无码专区 | 精品亚洲韩国一区二区三区 | 久久久久亚洲精品男人的天堂 | 久久精品人人做人人综合试看 | 三级4级全黄60分钟 | 成在人线av无码免费 | 人妻中文无码久热丝袜 | 沈阳熟女露脸对白视频 | 亚洲男女内射在线播放 | 久久国产精品萌白酱免费 | 日日噜噜噜噜夜夜爽亚洲精品 | 国产亚洲精品久久久久久 | 国内精品一区二区三区不卡 | 天堂а√在线中文在线 | 性史性农村dvd毛片 | 亚洲熟妇自偷自拍另类 | 亚洲国产精品美女久久久久 | 欧美放荡的少妇 | 老子影院午夜伦不卡 | 六十路熟妇乱子伦 | 久久精品视频在线看15 | 老子影院午夜精品无码 | 天堂一区人妻无码 | 亚洲无人区午夜福利码高清完整版 | 性色欲网站人妻丰满中文久久不卡 | 精品国产一区av天美传媒 | 免费人成网站视频在线观看 | 人人爽人人爽人人片av亚洲 | 2020久久超碰国产精品最新 | 国产艳妇av在线观看果冻传媒 | 亚洲一区二区三区在线观看网站 | 熟妇人妻激情偷爽文 | 999久久久国产精品消防器材 | 一个人看的视频www在线 | 欧美猛少妇色xxxxx | 少妇久久久久久人妻无码 | 99麻豆久久久国产精品免费 | 国产精品.xx视频.xxtv | 黑森林福利视频导航 | 亚洲精品久久久久中文第一幕 | 伊人久久大香线焦av综合影院 | 国产激情艳情在线看视频 | 亚洲精品成人av在线 | 欧美人与物videos另类 | 成人试看120秒体验区 | 18禁止看的免费污网站 | 亚洲色欲久久久综合网东京热 | 色一情一乱一伦一视频免费看 | 国产精品久久久久久久9999 | 亚洲精品久久久久久一区二区 | 鲁鲁鲁爽爽爽在线视频观看 | 中文无码伦av中文字幕 | 亚洲爆乳无码专区 | 极品尤物被啪到呻吟喷水 | 亚洲 激情 小说 另类 欧美 | 中文字幕乱码人妻无码久久 | 国产午夜无码视频在线观看 | 国产在热线精品视频 | 国产免费观看黄av片 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 亚洲国产一区二区三区在线观看 | 亚洲成a人片在线观看无码3d | 亚洲日韩av一区二区三区中文 | 18禁黄网站男男禁片免费观看 | 亚洲精品中文字幕乱码 | 日日摸夜夜摸狠狠摸婷婷 | 国产成人一区二区三区在线观看 | 亚洲自偷自拍另类第1页 | 无码人妻久久一区二区三区不卡 | 熟女体下毛毛黑森林 | 人妻无码久久精品人妻 | 免费观看又污又黄的网站 | 又粗又大又硬又长又爽 | 天堂久久天堂av色综合 | 99久久婷婷国产综合精品青草免费 | 亚拍精品一区二区三区探花 | 亚洲国产av美女网站 | 少妇的肉体aa片免费 | 欧美喷潮久久久xxxxx | 国产成人一区二区三区别 | 成人欧美一区二区三区黑人免费 | 亚洲精品午夜国产va久久成人 | 九月婷婷人人澡人人添人人爽 | 成人免费视频视频在线观看 免费 | 久久国产36精品色熟妇 | 亚洲国产精品久久人人爱 | 九九热爱视频精品 | 中文亚洲成a人片在线观看 | 久久精品国产亚洲精品 | 天堂а√在线地址中文在线 | 亚洲成a人片在线观看日本 | 亚洲va欧美va天堂v国产综合 | 久久99精品久久久久久 | 性色av无码免费一区二区三区 | 熟女少妇在线视频播放 | 国产香蕉尹人视频在线 | 天天躁夜夜躁狠狠是什么心态 | 欧美激情综合亚洲一二区 | 麻豆国产丝袜白领秘书在线观看 | 欧美成人家庭影院 | 亚洲成av人片天堂网无码】 | 亚洲日韩av片在线观看 | 亚洲精品一区二区三区婷婷月 | 国产精品多人p群无码 | 无码吃奶揉捏奶头高潮视频 | 久久亚洲日韩精品一区二区三区 | 午夜精品久久久久久久 | 在线观看欧美一区二区三区 | 国产亚洲精品久久久久久国模美 | 久激情内射婷内射蜜桃人妖 | 亚洲自偷自拍另类第1页 | 乱人伦中文视频在线观看 | 99视频精品全部免费免费观看 | 无码纯肉视频在线观看 | 国产乱码精品一品二品 | 亚洲日韩av一区二区三区四区 | 国产无套粉嫩白浆在线 | 国产精品丝袜黑色高跟鞋 | 亚洲a无码综合a国产av中文 | 亚洲s码欧洲m码国产av | 日韩精品一区二区av在线 | 99久久久无码国产aaa精品 | 一本大道久久东京热无码av | 欧美三级a做爰在线观看 | 内射巨臀欧美在线视频 | 亚洲天堂2017无码中文 | 性欧美熟妇videofreesex | 亚洲熟妇色xxxxx欧美老妇y | 国产深夜福利视频在线 | 7777奇米四色成人眼影 | 国产网红无码精品视频 | 国产另类ts人妖一区二区 | 亚洲va中文字幕无码久久不卡 | 狂野欧美性猛xxxx乱大交 | 人妻少妇被猛烈进入中文字幕 | 成在人线av无码免费 | 97精品国产97久久久久久免费 | 两性色午夜视频免费播放 | 成人亚洲精品久久久久软件 | 男人扒开女人内裤强吻桶进去 | 高潮毛片无遮挡高清免费 | 亲嘴扒胸摸屁股激烈网站 | 国模大胆一区二区三区 | а√天堂www在线天堂小说 | 男人扒开女人内裤强吻桶进去 | 日本大香伊一区二区三区 | 亚洲日韩av一区二区三区中文 | 67194成是人免费无码 | 无码一区二区三区在线观看 | 亚洲国产欧美国产综合一区 | 亚洲熟妇自偷自拍另类 | 人妻插b视频一区二区三区 | 国产9 9在线 | 中文 | 国产精品办公室沙发 | 欧美大屁股xxxxhd黑色 | 欧美亚洲国产一区二区三区 | 欧洲美熟女乱又伦 | 少妇无码吹潮 | 中文无码伦av中文字幕 | 在线观看国产午夜福利片 | 亚洲综合另类小说色区 | 欧美激情一区二区三区成人 | 5858s亚洲色大成网站www | 国产精品久久久久7777 | 国产精品久久久久久久影院 | 亚洲 激情 小说 另类 欧美 | 蜜臀av无码人妻精品 | 一区二区传媒有限公司 | 亚洲人成影院在线无码按摩店 | 狂野欧美激情性xxxx | 亚洲狠狠婷婷综合久久 | 爽爽影院免费观看 | av无码电影一区二区三区 | 国产超碰人人爽人人做人人添 | 88国产精品欧美一区二区三区 | 亚洲日韩一区二区 | 亚洲狠狠婷婷综合久久 | 午夜精品久久久久久久 | 老子影院午夜精品无码 | 女人被男人躁得好爽免费视频 | 久久久久久久久蜜桃 | 中文字幕av无码一区二区三区电影 | 日韩 欧美 动漫 国产 制服 | 免费无码肉片在线观看 | 国内精品九九久久久精品 | 久久久国产一区二区三区 | 国产xxx69麻豆国语对白 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 桃花色综合影院 | www成人国产高清内射 | 精品国产一区二区三区av 性色 | 亚洲综合另类小说色区 | 国产免费无码一区二区视频 | 人妻尝试又大又粗久久 | 国产成人无码av在线影院 | 少妇人妻av毛片在线看 | 清纯唯美经典一区二区 | 国产精品久久久久无码av色戒 | www一区二区www免费 | 欧美 丝袜 自拍 制服 另类 | 少妇高潮喷潮久久久影院 | 国产精品va在线播放 | 青青青手机频在线观看 | 欧美freesex黑人又粗又大 | 久久久久成人精品免费播放动漫 | 久久久久久av无码免费看大片 | 国产在线无码精品电影网 | 性做久久久久久久免费看 | 国产人妻精品一区二区三区不卡 | 亚洲中文字幕va福利 | 久久亚洲中文字幕无码 | 婷婷色婷婷开心五月四房播播 | 88国产精品欧美一区二区三区 | 熟妇女人妻丰满少妇中文字幕 | 国产va免费精品观看 | 日韩精品无码一本二本三本色 | 亚洲成a人片在线观看日本 | 日韩在线不卡免费视频一区 | 男人的天堂2018无码 | 狂野欧美性猛交免费视频 | 野狼第一精品社区 | 99久久久无码国产aaa精品 | 中文精品无码中文字幕无码专区 | 欧美xxxx黑人又粗又长 | 欧美35页视频在线观看 | 亚洲狠狠婷婷综合久久 | 国产亚洲精品久久久久久国模美 | 久久综合九色综合欧美狠狠 | 国产成人综合美国十次 | 国产精品久久久午夜夜伦鲁鲁 | 初尝人妻少妇中文字幕 | 色婷婷综合激情综在线播放 | 狠狠躁日日躁夜夜躁2020 | 久久国产36精品色熟妇 | 男人的天堂2018无码 | 亚洲精品成人福利网站 | 男人和女人高潮免费网站 | 国产av一区二区三区最新精品 | 又粗又大又硬又长又爽 | 暴力强奷在线播放无码 | 国产亚洲精品久久久ai换 | 在线视频网站www色 | 综合网日日天干夜夜久久 | 丝袜美腿亚洲一区二区 | 无套内射视频囯产 | 99久久无码一区人妻 | 999久久久国产精品消防器材 | 免费人成网站视频在线观看 | 国产精品嫩草久久久久 | 亚洲日韩av片在线观看 | 国产特级毛片aaaaaa高潮流水 | 日本www一道久久久免费榴莲 | 亚洲精品一区三区三区在线观看 | 天天爽夜夜爽夜夜爽 | 狠狠综合久久久久综合网 | a在线观看免费网站大全 | 超碰97人人做人人爱少妇 | 国产精品成人av在线观看 | 久久99精品久久久久久 | 亚洲精品成a人在线观看 | 欧美 日韩 人妻 高清 中文 | 玩弄少妇高潮ⅹxxxyw | 成人试看120秒体验区 | 国产成人精品三级麻豆 | 国产精品香蕉在线观看 | 波多野结衣 黑人 | 久久久久久久人妻无码中文字幕爆 | 无码人妻少妇伦在线电影 | 亚洲一区二区三区在线观看网站 | 高潮喷水的毛片 | 国产乱码精品一品二品 | 纯爱无遮挡h肉动漫在线播放 | 久久99精品久久久久婷婷 | 亚洲综合在线一区二区三区 | 久久精品一区二区三区四区 | 亚洲熟妇色xxxxx欧美老妇 | 波多野结衣一区二区三区av免费 | 久久人人爽人人爽人人片av高清 | 日本一区二区更新不卡 | 欧美老妇交乱视频在线观看 | 精品国产成人一区二区三区 | 国内精品人妻无码久久久影院 | 久久人人爽人人爽人人片ⅴ | 亚洲国产精品久久人人爱 | av无码久久久久不卡免费网站 | 久久人人爽人人人人片 | 亚洲熟悉妇女xxx妇女av | 亚洲精品一区三区三区在线观看 | 水蜜桃av无码 | 99精品久久毛片a片 | 亚洲国产精品无码久久久久高潮 | 日韩在线不卡免费视频一区 | 色欲综合久久中文字幕网 | 欧美三级不卡在线观看 | 中文无码成人免费视频在线观看 | 少妇高潮喷潮久久久影院 | 人妻少妇被猛烈进入中文字幕 | 日本熟妇人妻xxxxx人hd | 国产精品久久久一区二区三区 | 国产亚洲tv在线观看 | 丰满护士巨好爽好大乳 | 久久99精品国产.久久久久 | 日韩精品a片一区二区三区妖精 | 日本熟妇人妻xxxxx人hd | 中文字幕无码热在线视频 | 色综合久久中文娱乐网 | 熟女少妇人妻中文字幕 | 黑人粗大猛烈进出高潮视频 | 丰满人妻翻云覆雨呻吟视频 | 亚洲日韩av一区二区三区中文 | 久久久久久亚洲精品a片成人 | 人人妻人人澡人人爽欧美精品 | 丰满诱人的人妻3 | 国产免费久久精品国产传媒 | 亚洲精品中文字幕乱码 | 国产精品嫩草久久久久 | 久久精品国产大片免费观看 | 久久国产劲爆∧v内射 | 精品国偷自产在线 | 麻豆成人精品国产免费 | 久久久久久久人妻无码中文字幕爆 | 精品无码成人片一区二区98 | 麻豆av传媒蜜桃天美传媒 | 露脸叫床粗话东北少妇 | 天堂亚洲2017在线观看 | 一本久道高清无码视频 | 日日橹狠狠爱欧美视频 | 亚洲中文无码av永久不收费 | 国产黑色丝袜在线播放 | 精品国产一区二区三区四区 | 香蕉久久久久久av成人 | 国产99久久精品一区二区 | 人妻无码αv中文字幕久久琪琪布 | 乱人伦人妻中文字幕无码 | 真人与拘做受免费视频一 | 国产午夜亚洲精品不卡下载 | 国产激情一区二区三区 | 亚洲成av人影院在线观看 | 女人被爽到呻吟gif动态图视看 | 色欲人妻aaaaaaa无码 | 成人精品视频一区二区三区尤物 | 国产精品美女久久久久av爽李琼 | 日韩精品一区二区av在线 | 国产av人人夜夜澡人人爽麻豆 | 欧美日韩久久久精品a片 | 又大又黄又粗又爽的免费视频 | 亚洲国产午夜精品理论片 | 偷窥村妇洗澡毛毛多 | 亚洲中文字幕在线无码一区二区 | 亚洲精品一区三区三区在线观看 | 国产精品a成v人在线播放 | 欧美成人高清在线播放 | 超碰97人人做人人爱少妇 | 天堂а√在线地址中文在线 | 伊人久久婷婷五月综合97色 | 精品国产一区二区三区av 性色 | 男女下面进入的视频免费午夜 | 亚洲欧洲中文日韩av乱码 | 野狼第一精品社区 | 亚洲欧洲日本无在线码 | 精品无人区无码乱码毛片国产 | 国模大胆一区二区三区 | 国产精品亚洲综合色区韩国 | 亚洲精品一区二区三区在线观看 | 欧美自拍另类欧美综合图片区 | 久久久无码中文字幕久... | 无码一区二区三区在线观看 | 国产黄在线观看免费观看不卡 | 波多野结衣一区二区三区av免费 | 国产偷抇久久精品a片69 | 国产在线精品一区二区三区直播 | 久久亚洲中文字幕精品一区 | 亚洲国产成人a精品不卡在线 | 极品尤物被啪到呻吟喷水 | 色综合久久久久综合一本到桃花网 | 日本精品久久久久中文字幕 | 国产精品久久国产三级国 | 国产成人精品无码播放 | 无遮挡啪啪摇乳动态图 | 成人三级无码视频在线观看 | 亚洲熟妇自偷自拍另类 | 亚洲综合无码久久精品综合 | 久久亚洲国产成人精品性色 | 98国产精品综合一区二区三区 | 天堂亚洲2017在线观看 | 久久国产劲爆∧v内射 | 无码人妻黑人中文字幕 | 成人综合网亚洲伊人 | 波多野结衣av一区二区全免费观看 | 中文字幕乱码中文乱码51精品 | www成人国产高清内射 | 国产成人无码a区在线观看视频app | 久久视频在线观看精品 | 俺去俺来也在线www色官网 | 中文字幕无码日韩专区 | 少妇人妻大乳在线视频 | 国产另类ts人妖一区二区 | 久久综合久久自在自线精品自 | 一本精品99久久精品77 | 亚洲中文字幕av在天堂 | 中文无码精品a∨在线观看不卡 | 中文字幕 亚洲精品 第1页 | 精品国产成人一区二区三区 | 国产性生交xxxxx无码 | 中文字幕无码人妻少妇免费 | 中文字幕乱码人妻无码久久 | 人妻互换免费中文字幕 | 国产熟女一区二区三区四区五区 | 成人无码精品一区二区三区 | 国产午夜福利亚洲第一 | 日韩精品a片一区二区三区妖精 | 中文字幕乱码人妻无码久久 | 97久久超碰中文字幕 | 国产另类ts人妖一区二区 | 日韩精品无码一区二区中文字幕 | 乱人伦人妻中文字幕无码 | 亚洲精品久久久久久久久久久 | 乌克兰少妇xxxx做受 | 成人无码影片精品久久久 | 成人精品一区二区三区中文字幕 | 极品嫩模高潮叫床 | 久久国产精品二国产精品 | 亚洲国产精品久久久久久 | 日本一区二区三区免费播放 | 亚洲区小说区激情区图片区 | 国产小呦泬泬99精品 | 久久婷婷五月综合色国产香蕉 | 国产猛烈高潮尖叫视频免费 | 欧美精品免费观看二区 | 在线观看国产午夜福利片 | 久久国语露脸国产精品电影 | 亚洲大尺度无码无码专区 | 无码任你躁久久久久久久 | 黑人粗大猛烈进出高潮视频 | 偷窥日本少妇撒尿chinese | 国产精品永久免费视频 | 亚洲综合精品香蕉久久网 | 东京热男人av天堂 | 亚洲高清偷拍一区二区三区 | 久久99精品久久久久久动态图 | 午夜时刻免费入口 | 久久午夜无码鲁丝片午夜精品 | 无码国模国产在线观看 | 国产美女精品一区二区三区 | 最近的中文字幕在线看视频 | 国产精品资源一区二区 | 国内揄拍国内精品少妇国语 | 乱人伦中文视频在线观看 | 高清国产亚洲精品自在久久 | 高清国产亚洲精品自在久久 | 国产精品久久精品三级 | 青青青手机频在线观看 | 99久久婷婷国产综合精品青草免费 | 久久亚洲精品中文字幕无男同 | 亚洲自偷自拍另类第1页 | 久在线观看福利视频 | 无人区乱码一区二区三区 | 日本在线高清不卡免费播放 | 国产一区二区不卡老阿姨 | 亚洲综合无码久久精品综合 | 四虎永久在线精品免费网址 | 日韩精品乱码av一区二区 | 亚洲精品美女久久久久久久 | 中文亚洲成a人片在线观看 | 国产亚洲精品久久久久久国模美 | 久久99精品久久久久婷婷 | 欧美成人家庭影院 | 国产办公室秘书无码精品99 | 色婷婷欧美在线播放内射 | 综合网日日天干夜夜久久 | 黑人巨大精品欧美黑寡妇 | 日本一区二区三区免费高清 | 亚洲成熟女人毛毛耸耸多 | 亚洲乱亚洲乱妇50p | 国产成人精品视频ⅴa片软件竹菊 | 一本久久a久久精品vr综合 | a国产一区二区免费入口 | 日本高清一区免费中文视频 | 激情国产av做激情国产爱 | 国产另类ts人妖一区二区 | 日本一卡2卡3卡四卡精品网站 | 久久国产精品_国产精品 | 九九在线中文字幕无码 | 内射爽无广熟女亚洲 | 成人欧美一区二区三区 | 丰满护士巨好爽好大乳 | 丰满护士巨好爽好大乳 | 四虎国产精品一区二区 | 无码免费一区二区三区 | 成人aaa片一区国产精品 | 亚洲午夜福利在线观看 | 东京一本一道一二三区 | 亚洲日韩一区二区 | 国产电影无码午夜在线播放 | 国产乡下妇女做爰 | 亚洲熟妇自偷自拍另类 | 日本精品久久久久中文字幕 | 亚无码乱人伦一区二区 | 国产特级毛片aaaaaaa高清 | 成熟女人特级毛片www免费 | 久久视频在线观看精品 | 亚洲乱亚洲乱妇50p | 青青草原综合久久大伊人精品 | 真人与拘做受免费视频一 | 国产区女主播在线观看 | 亚洲色偷偷男人的天堂 | 日韩在线不卡免费视频一区 | 国产综合在线观看 | 麻豆国产97在线 | 欧洲 | 窝窝午夜理论片影院 | 双乳奶水饱满少妇呻吟 | 久久精品一区二区三区四区 | 久久久久久av无码免费看大片 | 国产亚av手机在线观看 | 婷婷丁香六月激情综合啪 | 国产深夜福利视频在线 | 蜜臀aⅴ国产精品久久久国产老师 | 国产综合在线观看 | 日韩少妇白浆无码系列 | 国内精品久久毛片一区二区 | 国内精品人妻无码久久久影院蜜桃 | 婷婷五月综合缴情在线视频 | 国产无av码在线观看 | 麻豆成人精品国产免费 | 97人妻精品一区二区三区 | 欧美日韩综合一区二区三区 | 欧美日韩综合一区二区三区 | 亚洲精品国产品国语在线观看 | 亚洲中文字幕av在天堂 | 国产免费观看黄av片 | 麻豆果冻传媒2021精品传媒一区下载 | 亚洲国产综合无码一区 | 国产精品亚洲五月天高清 | 性欧美牲交xxxxx视频 | 国产农村乱对白刺激视频 | 国产一区二区三区日韩精品 | 久久久久久久久888 | 扒开双腿疯狂进出爽爽爽视频 | 国产亚洲欧美日韩亚洲中文色 | 久久久久久a亚洲欧洲av冫 | 成人av无码一区二区三区 | √天堂中文官网8在线 | 亚洲成a人片在线观看无码 | 四十如虎的丰满熟妇啪啪 | 亚洲s色大片在线观看 | 在线看片无码永久免费视频 | 成人欧美一区二区三区 | 久久精品人人做人人综合 | 亚洲精品久久久久久一区二区 | 中文字幕无码av波多野吉衣 | 粉嫩少妇内射浓精videos | 人人妻人人澡人人爽人人精品 | 国产精品久久久久久亚洲影视内衣 | 九九热爱视频精品 | 欧美zoozzooz性欧美 | 亚洲日韩av片在线观看 | 狂野欧美性猛交免费视频 | 我要看www免费看插插视频 | 荫蒂添的好舒服视频囗交 | 综合人妻久久一区二区精品 | 国产三级精品三级男人的天堂 | 九月婷婷人人澡人人添人人爽 | 国产精品理论片在线观看 | 7777奇米四色成人眼影 | 午夜福利一区二区三区在线观看 | 国内精品一区二区三区不卡 | 99久久精品午夜一区二区 | 美女毛片一区二区三区四区 | 国产口爆吞精在线视频 | 亚洲国产高清在线观看视频 | 中文字幕无码av激情不卡 | 水蜜桃亚洲一二三四在线 | 牛和人交xxxx欧美 | 青青草原综合久久大伊人精品 | 日本一本二本三区免费 | 国产亚洲精品久久久久久国模美 | 波多野结衣高清一区二区三区 | 麻豆国产人妻欲求不满 | 精品欧洲av无码一区二区三区 | 国产 浪潮av性色四虎 | 国产精品资源一区二区 | 国产肉丝袜在线观看 | 亚洲精品一区二区三区婷婷月 | 日本成熟视频免费视频 | 国产成人无码午夜视频在线观看 | 国产色精品久久人妻 | 国产激情综合五月久久 | 狠狠噜狠狠狠狠丁香五月 | 性史性农村dvd毛片 | 九九热爱视频精品 | 国产人妖乱国产精品人妖 | 亚洲毛片av日韩av无码 | 夜夜躁日日躁狠狠久久av | 粗大的内捧猛烈进出视频 | 国产真人无遮挡作爱免费视频 | 鲁鲁鲁爽爽爽在线视频观看 | 久久人人爽人人人人片 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 奇米影视7777久久精品 | 国产三级久久久精品麻豆三级 | 51国偷自产一区二区三区 | 国产三级精品三级男人的天堂 | 亚洲国产欧美国产综合一区 | 国产内射老熟女aaaa | 色综合久久久无码中文字幕 | 久久国产36精品色熟妇 | 人人妻人人澡人人爽欧美精品 | 日本精品久久久久中文字幕 | 国产精品人人爽人人做我的可爱 | 久久精品国产一区二区三区肥胖 | 狠狠色丁香久久婷婷综合五月 | 日日麻批免费40分钟无码 | 久久亚洲中文字幕无码 | 日日夜夜撸啊撸 | 成人影院yy111111在线观看 | 国精品人妻无码一区二区三区蜜柚 | 国产人妻久久精品二区三区老狼 | 性色欲情网站iwww九文堂 | 一个人免费观看的www视频 | 在线播放亚洲第一字幕 | 欧美国产日韩久久mv | 国精产品一品二品国精品69xx | 亚洲熟妇色xxxxx欧美老妇y | 久久久久人妻一区精品色欧美 | 四虎4hu永久免费 | 夜精品a片一区二区三区无码白浆 | 国内精品久久久久久中文字幕 | 无码av中文字幕免费放 | 日韩av激情在线观看 | 亚洲精品成人av在线 | 成人精品天堂一区二区三区 | 久久久久久久人妻无码中文字幕爆 | 无码人妻精品一区二区三区下载 | 一本大道伊人av久久综合 | 亚洲 激情 小说 另类 欧美 | 久9re热视频这里只有精品 | 欧美人妻一区二区三区 | 成人亚洲精品久久久久软件 | 婷婷五月综合激情中文字幕 | 亚洲精品中文字幕乱码 | 老熟女重囗味hdxx69 | 又大又黄又粗又爽的免费视频 | 亚洲精品久久久久avwww潮水 | av在线亚洲欧洲日产一区二区 | 无套内射视频囯产 | 亚洲小说春色综合另类 | 亚洲中文字幕在线无码一区二区 | 色窝窝无码一区二区三区色欲 | 天堂а√在线中文在线 | 日韩成人一区二区三区在线观看 | 久久这里只有精品视频9 | 亚洲国精产品一二二线 | 免费男性肉肉影院 | 国产欧美精品一区二区三区 | 国产精品无码一区二区桃花视频 | 欧美放荡的少妇 | 欧洲精品码一区二区三区免费看 | 少妇久久久久久人妻无码 | 我要看www免费看插插视频 | а√资源新版在线天堂 | 国产精品国产自线拍免费软件 | 久9re热视频这里只有精品 | 国产熟妇高潮叫床视频播放 | 大色综合色综合网站 | 青春草在线视频免费观看 | 欧美大屁股xxxxhd黑色 | 国产精品人人爽人人做我的可爱 | 性史性农村dvd毛片 | 日产精品99久久久久久 | 人妻少妇精品无码专区动漫 | 99精品视频在线观看免费 | 一区二区三区乱码在线 | 欧洲 | 大屁股大乳丰满人妻 | 综合人妻久久一区二区精品 | 久久aⅴ免费观看 | 中文字幕无码人妻少妇免费 | 久久久亚洲欧洲日产国码αv | 亚洲国产欧美日韩精品一区二区三区 | 动漫av网站免费观看 | 国语自产偷拍精品视频偷 | 亚洲欧洲日本综合aⅴ在线 | 狠狠躁日日躁夜夜躁2020 | √天堂中文官网8在线 | 伊人久久大香线焦av综合影院 | 欧美freesex黑人又粗又大 | 色五月五月丁香亚洲综合网 | 女人被男人躁得好爽免费视频 | 中文字幕无码免费久久99 | 国产欧美精品一区二区三区 | 国产色xx群视频射精 | 国产偷抇久久精品a片69 | 国产乱人伦av在线无码 | 亚洲一区二区三区含羞草 | 亚洲中文字幕成人无码 | 中文字幕av无码一区二区三区电影 | 无遮挡啪啪摇乳动态图 | 亚洲中文字幕无码中文字在线 | 亚洲成在人网站无码天堂 | 国产超碰人人爽人人做人人添 | 久久天天躁狠狠躁夜夜免费观看 | 99久久婷婷国产综合精品青草免费 | 性欧美videos高清精品 | 7777奇米四色成人眼影 | 国产美女极度色诱视频www | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产小呦泬泬99精品 | 丝袜 中出 制服 人妻 美腿 | 国产成人无码a区在线观看视频app | 乱码av麻豆丝袜熟女系列 | 亚洲国产成人av在线观看 | 色婷婷久久一区二区三区麻豆 | 成人影院yy111111在线观看 | 国产激情无码一区二区 | 全黄性性激高免费视频 | 精品aⅴ一区二区三区 | 久久久无码中文字幕久... | 欧美亚洲日韩国产人成在线播放 | 99久久精品午夜一区二区 | 久久99热只有频精品8 | 亚洲欧美日韩成人高清在线一区 | 午夜男女很黄的视频 | 精品国产一区二区三区av 性色 | 中文字幕无码日韩专区 | 无码一区二区三区在线观看 | 欧美大屁股xxxxhd黑色 | 成人性做爰aaa片免费看不忠 | 日日橹狠狠爱欧美视频 | 伊人久久大香线蕉午夜 | 成熟人妻av无码专区 | 日韩人妻无码中文字幕视频 | 天天摸天天碰天天添 | 中文字幕无码免费久久9一区9 | 色综合久久中文娱乐网 | 熟女少妇人妻中文字幕 | 亚洲国产精品成人久久蜜臀 | 又色又爽又黄的美女裸体网站 | 国产偷国产偷精品高清尤物 | 国产人妻精品午夜福利免费 | 久久精品99久久香蕉国产色戒 | 97色伦图片97综合影院 | 国产av无码专区亚洲awww | av无码不卡在线观看免费 | 久久久精品人妻久久影视 | 亚洲精品成a人在线观看 | 日日天日日夜日日摸 | 久久久久久久人妻无码中文字幕爆 | 牲欲强的熟妇农村老妇女 | 欧美性生交活xxxxxdddd | 日韩在线不卡免费视频一区 | 日韩 欧美 动漫 国产 制服 | 国产亚洲精品久久久久久久 | 亚洲欧洲日本无在线码 | 亚洲综合无码一区二区三区 | 丝袜 中出 制服 人妻 美腿 | 中文字幕中文有码在线 | 六月丁香婷婷色狠狠久久 | 亚洲自偷精品视频自拍 | 国产xxx69麻豆国语对白 | 国产97人人超碰caoprom | 四虎国产精品免费久久 | 国产后入清纯学生妹 | 熟女俱乐部五十路六十路av | 日日干夜夜干 | 未满成年国产在线观看 | 妺妺窝人体色www婷婷 | 精品国偷自产在线 | 日本熟妇人妻xxxxx人hd | 精品欧洲av无码一区二区三区 | 在线亚洲高清揄拍自拍一品区 | 国产精品99爱免费视频 | 国产av久久久久精东av | 人人澡人人妻人人爽人人蜜桃 | 综合网日日天干夜夜久久 | 亚洲中文字幕无码一久久区 | 欧美激情一区二区三区成人 | 好男人社区资源 | 最近的中文字幕在线看视频 | 久久久久国色av免费观看性色 | 无码人妻出轨黑人中文字幕 | 国内少妇偷人精品视频 | 最新国产乱人伦偷精品免费网站 | 纯爱无遮挡h肉动漫在线播放 | 乱人伦人妻中文字幕无码 | 综合激情五月综合激情五月激情1 | 久久 国产 尿 小便 嘘嘘 | 亚洲综合另类小说色区 | 强开小婷嫩苞又嫩又紧视频 | 熟妇人妻中文av无码 | 国产精品久久久久无码av色戒 | 双乳奶水饱满少妇呻吟 | 日韩人妻系列无码专区 | 色情久久久av熟女人妻网站 | 熟女俱乐部五十路六十路av | 亚洲人成影院在线观看 | 男女超爽视频免费播放 | 九九在线中文字幕无码 | 久久精品中文字幕大胸 | 又粗又大又硬毛片免费看 | 中国女人内谢69xxxx | 漂亮人妻洗澡被公强 日日躁 | 久久zyz资源站无码中文动漫 | 亚洲熟妇色xxxxx欧美老妇y | 国产片av国语在线观看 | 99久久久国产精品无码免费 | 欧美freesex黑人又粗又大 | 亚洲成av人影院在线观看 | 久久久久久国产精品无码下载 | 最近免费中文字幕中文高清百度 | 色情久久久av熟女人妻网站 | 亚洲の无码国产の无码影院 | 97资源共享在线视频 | 波多野结衣 黑人 | 丰满人妻被黑人猛烈进入 | 久久久av男人的天堂 | 国产精品久久久久久亚洲影视内衣 | 丰满岳乱妇在线观看中字无码 | 成年美女黄网站色大免费视频 | 国产精品无码永久免费888 | 国产九九九九九九九a片 | 精品少妇爆乳无码av无码专区 | 国产亚av手机在线观看 | 国产欧美精品一区二区三区 | 在线精品国产一区二区三区 | 小鲜肉自慰网站xnxx | 国产人妖乱国产精品人妖 | 久久国产精品偷任你爽任你 | 久久国语露脸国产精品电影 | 精品夜夜澡人妻无码av蜜桃 | 亚洲一区二区三区偷拍女厕 | 色一情一乱一伦一视频免费看 | 日日摸夜夜摸狠狠摸婷婷 | 国产深夜福利视频在线 | 国产无遮挡又黄又爽又色 | 日韩精品无码一区二区中文字幕 | av人摸人人人澡人人超碰下载 | 成 人 免费观看网站 | 精品国产青草久久久久福利 | 一本久久a久久精品亚洲 | 欧美成人家庭影院 | 牲欲强的熟妇农村老妇女视频 | 少妇人妻大乳在线视频 | 亚洲欧洲日本综合aⅴ在线 | 7777奇米四色成人眼影 | 国产精品成人av在线观看 | 狠狠躁日日躁夜夜躁2020 | 国产无遮挡吃胸膜奶免费看 | 无遮挡啪啪摇乳动态图 | 狠狠色噜噜狠狠狠狠7777米奇 | 精品无人区无码乱码毛片国产 | 日本欧美一区二区三区乱码 | 亚洲阿v天堂在线 | 又湿又紧又大又爽a视频国产 | 中文字幕中文有码在线 | 人妻夜夜爽天天爽三区 | 久久亚洲精品中文字幕无男同 | 国产亚洲日韩欧美另类第八页 | 亚洲一区二区三区含羞草 | 捆绑白丝粉色jk震动捧喷白浆 | 亚洲伊人久久精品影院 | 亚洲综合久久一区二区 | 精品人人妻人人澡人人爽人人 | 中文字幕av日韩精品一区二区 | 三上悠亚人妻中文字幕在线 | 国产亚洲精品久久久ai换 | 国产精品永久免费视频 | 色综合久久88色综合天天 | 波多野结衣一区二区三区av免费 | 亚洲综合无码一区二区三区 | 久久aⅴ免费观看 | 亚洲国产精品毛片av不卡在线 | 国内少妇偷人精品视频免费 | 中文字幕无码av激情不卡 | 欧美黑人乱大交 | 综合激情五月综合激情五月激情1 | 国产色在线 | 国产 | 亚洲欧美日韩国产精品一区二区 | 亚洲国产日韩a在线播放 | 国产精品久久久午夜夜伦鲁鲁 | 欧美丰满熟妇xxxx | 久久久中文久久久无码 | 久久亚洲日韩精品一区二区三区 | 国产高清av在线播放 | 人妻无码久久精品人妻 | 亚洲欧美日韩综合久久久 | 国产精品久久久久久久影院 | 国产莉萝无码av在线播放 | 捆绑白丝粉色jk震动捧喷白浆 | 久久午夜无码鲁丝片 | 九九久久精品国产免费看小说 | 日日摸日日碰夜夜爽av | 又黄又爽又色的视频 | 久久久久久久久蜜桃 | 中文字幕无码免费久久9一区9 | 东京一本一道一二三区 | 日本丰满护士爆乳xxxx | 亚洲啪av永久无码精品放毛片 | 亚洲自偷精品视频自拍 | 亚洲一区二区三区 | 欧美丰满熟妇xxxx性ppx人交 | 无码人妻av免费一区二区三区 | 欧美日韩一区二区综合 | 中文字幕无线码免费人妻 | 久久久av男人的天堂 | 亚洲欧美精品伊人久久 | 熟妇人妻激情偷爽文 | 色综合久久中文娱乐网 | 欧美老妇交乱视频在线观看 | 久久综合激激的五月天 | 无码一区二区三区在线观看 | 一个人免费观看的www视频 | 日韩av无码一区二区三区 | 无码av岛国片在线播放 | 亚洲成a人片在线观看日本 | 蜜桃视频韩日免费播放 | 久久久久久久久888 | 亚洲の无码国产の无码影院 | 中国女人内谢69xxxxxa片 | 高潮喷水的毛片 | 国産精品久久久久久久 | 纯爱无遮挡h肉动漫在线播放 | 色诱久久久久综合网ywww | 东京热一精品无码av | 99视频精品全部免费免费观看 | 久久 国产 尿 小便 嘘嘘 | 无码人妻丰满熟妇区毛片18 | 日韩精品成人一区二区三区 | 色欲久久久天天天综合网精品 | 日本丰满护士爆乳xxxx | 欧美性生交活xxxxxdddd | 亚洲一区二区三区含羞草 | 国产亲子乱弄免费视频 | 性色欲网站人妻丰满中文久久不卡 | 国产三级久久久精品麻豆三级 | 天堂无码人妻精品一区二区三区 | 久久精品国产大片免费观看 | 亚洲中文字幕va福利 | 国产美女精品一区二区三区 | 精品偷自拍另类在线观看 | 欧美黑人乱大交 | 成人免费视频视频在线观看 免费 | 国产97人人超碰caoprom | 一本大道伊人av久久综合 | 久久久久久久久888 | 久久久久99精品成人片 | 国产av无码专区亚洲awww | 国产精品无码一区二区桃花视频 | 欧美肥老太牲交大战 | 秋霞特色aa大片 | 久久 国产 尿 小便 嘘嘘 | 天干天干啦夜天干天2017 | 日本一卡2卡3卡四卡精品网站 | 国产在线aaa片一区二区99 | 一本色道久久综合狠狠躁 | 欧美黑人乱大交 | 久久无码中文字幕免费影院蜜桃 | 精品成人av一区二区三区 | 久久精品国产大片免费观看 | 日本熟妇人妻xxxxx人hd | 国产美女极度色诱视频www | 免费无码午夜福利片69 | 精品国产乱码久久久久乱码 | 女人和拘做爰正片视频 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲午夜无码久久 | 国产精品欧美成人 | 色一情一乱一伦一区二区三欧美 | 国产又粗又硬又大爽黄老大爷视 | 97无码免费人妻超级碰碰夜夜 | 狠狠cao日日穞夜夜穞av | 丰满少妇高潮惨叫视频 | 99re在线播放 | 婷婷六月久久综合丁香 | 国产一精品一av一免费 | 18禁黄网站男男禁片免费观看 | 全球成人中文在线 | 精品国产青草久久久久福利 | 在线播放免费人成毛片乱码 | 午夜精品一区二区三区在线观看 | 久久国产劲爆∧v内射 | 国产精品第一国产精品 | 一个人看的视频www在线 | 日日碰狠狠丁香久燥 | 亚洲春色在线视频 | 日本又色又爽又黄的a片18禁 | 国产内射爽爽大片视频社区在线 | 人妻少妇精品无码专区二区 | 久久国产精品二国产精品 | 国产成人精品视频ⅴa片软件竹菊 | 18精品久久久无码午夜福利 | 久久亚洲国产成人精品性色 | 曰韩少妇内射免费播放 | 丰满人妻翻云覆雨呻吟视频 | 中文字幕av无码一区二区三区电影 | 人人澡人人妻人人爽人人蜜桃 | 久9re热视频这里只有精品 | 久久99精品国产麻豆 | 欧美阿v高清资源不卡在线播放 | 在线观看免费人成视频 | 国产av一区二区三区最新精品 | 又粗又大又硬又长又爽 | 午夜男女很黄的视频 | 好男人社区资源 | 无码人妻丰满熟妇区毛片18 | www成人国产高清内射 | 国产色视频一区二区三区 | 丝袜美腿亚洲一区二区 | 天堂亚洲免费视频 | 精品 日韩 国产 欧美 视频 | 精品无人区无码乱码毛片国产 | 国产熟女一区二区三区四区五区 | 人人妻人人澡人人爽人人精品浪潮 | 国产sm调教视频在线观看 | 久久精品人人做人人综合试看 | 久激情内射婷内射蜜桃人妖 | 国产午夜亚洲精品不卡下载 | 精品无码国产自产拍在线观看蜜 | 99精品视频在线观看免费 | 精品无码国产自产拍在线观看蜜 | 强开小婷嫩苞又嫩又紧视频 | 日本一区二区三区免费播放 | 午夜丰满少妇性开放视频 | 精品国产国产综合精品 | 人妻中文无码久热丝袜 | 国产精品毛多多水多 | 久久久久久av无码免费看大片 | 国语自产偷拍精品视频偷 | 熟妇激情内射com | 成人试看120秒体验区 | 精品少妇爆乳无码av无码专区 | 少妇人妻大乳在线视频 | 午夜免费福利小电影 | 国产明星裸体无码xxxx视频 | 色欲久久久天天天综合网精品 | 在线a亚洲视频播放在线观看 | 一本久道久久综合婷婷五月 | 亚洲一区av无码专区在线观看 | 欧美大屁股xxxxhd黑色 | 无码av免费一区二区三区试看 | 亚洲综合无码一区二区三区 | 亚洲熟妇自偷自拍另类 | 人人妻人人澡人人爽欧美一区九九 | 久久精品国产日本波多野结衣 | 99久久99久久免费精品蜜桃 | 亚洲人亚洲人成电影网站色 | 精品人妻人人做人人爽夜夜爽 | 亚洲精品欧美二区三区中文字幕 | 亚洲 日韩 欧美 成人 在线观看 | 欧美性生交活xxxxxdddd | 欧美丰满熟妇xxxx性ppx人交 | 日日夜夜撸啊撸 | 一区二区三区高清视频一 | 国产 精品 自在自线 | 人人澡人人妻人人爽人人蜜桃 | 西西人体www44rt大胆高清 | 中文久久乱码一区二区 | 欧美老妇交乱视频在线观看 | 国产亚洲精品久久久久久大师 | 欧美freesex黑人又粗又大 | 欧美性猛交内射兽交老熟妇 | 亚洲精品综合五月久久小说 | 亚洲男人av香蕉爽爽爽爽 | 粉嫩少妇内射浓精videos | aⅴ在线视频男人的天堂 | 两性色午夜免费视频 | 亚洲a无码综合a国产av中文 | 丁香啪啪综合成人亚洲 | 国产精品亚洲一区二区三区喷水 | 国产成人综合在线女婷五月99播放 | 亚洲精品一区二区三区大桥未久 | 中文字幕无码av激情不卡 | 免费视频欧美无人区码 | 又色又爽又黄的美女裸体网站 | 亚洲熟妇色xxxxx欧美老妇y | 国产成人久久精品流白浆 | 国产人妻人伦精品1国产丝袜 | 婷婷五月综合缴情在线视频 | 丁香花在线影院观看在线播放 | 久久久中文字幕日本无吗 | 日韩成人一区二区三区在线观看 | 色狠狠av一区二区三区 | 国产精品久久久久无码av色戒 | 成人精品一区二区三区中文字幕 | 狠狠色丁香久久婷婷综合五月 | 亚洲欧美国产精品久久 | 亚洲成av人片在线观看无码不卡 | 任你躁国产自任一区二区三区 | 女人和拘做爰正片视频 | 在线a亚洲视频播放在线观看 | 精品无人国产偷自产在线 | 日日碰狠狠丁香久燥 | 中国大陆精品视频xxxx | 女人被爽到呻吟gif动态图视看 | 麻豆果冻传媒2021精品传媒一区下载 | 98国产精品综合一区二区三区 | 国产精品99爱免费视频 | 亚洲狠狠婷婷综合久久 | 俺去俺来也在线www色官网 | 久久99精品久久久久久动态图 | 99久久亚洲精品无码毛片 | 中文字幕乱码人妻二区三区 | 亚洲一区二区三区国产精华液 | 成人免费无码大片a毛片 | 亚洲欧美国产精品专区久久 | 日本一卡二卡不卡视频查询 | 色老头在线一区二区三区 | 九一九色国产 | 1000部夫妻午夜免费 | 亚洲区欧美区综合区自拍区 | 在线天堂新版最新版在线8 | 色综合天天综合狠狠爱 | 全球成人中文在线 | 国产成人无码一二三区视频 | 久久99精品久久久久婷婷 | 色婷婷欧美在线播放内射 | 国精品人妻无码一区二区三区蜜柚 | 大乳丰满人妻中文字幕日本 | 国精产品一区二区三区 | 国产口爆吞精在线视频 | 日本免费一区二区三区最新 | 国产香蕉尹人视频在线 | 久久亚洲精品成人无码 | 日韩精品一区二区av在线 | 色五月丁香五月综合五月 | 欧美刺激性大交 | 国内精品人妻无码久久久影院蜜桃 | 久久久久免费看成人影片 | 欧美日韩久久久精品a片 | 国产又爽又黄又刺激的视频 | 国产农村乱对白刺激视频 | 国产黑色丝袜在线播放 | 97久久超碰中文字幕 | 伊在人天堂亚洲香蕉精品区 | 亚洲s码欧洲m码国产av | 又粗又大又硬毛片免费看 | 18禁黄网站男男禁片免费观看 | 国产女主播喷水视频在线观看 | 欧美国产日产一区二区 | 国产舌乚八伦偷品w中 | aⅴ在线视频男人的天堂 | 77777熟女视频在线观看 а天堂中文在线官网 | 成人欧美一区二区三区 | 欧美成人高清在线播放 | 久久久久亚洲精品男人的天堂 | 国产在线精品一区二区高清不卡 | 国产又爽又黄又刺激的视频 | 青青青手机频在线观看 | 又紧又大又爽精品一区二区 | 鲁一鲁av2019在线 | 免费网站看v片在线18禁无码 | 国产乱人偷精品人妻a片 | 国产无套内射久久久国产 | 国产亚洲精品久久久久久久 | 欧美黑人性暴力猛交喷水 | 香港三级日本三级妇三级 | 任你躁国产自任一区二区三区 | 亚洲乱码日产精品bd | 天天摸天天碰天天添 | 麻豆蜜桃av蜜臀av色欲av | 欧美熟妇另类久久久久久多毛 | 99久久亚洲精品无码毛片 | 成人无码精品1区2区3区免费看 | 国产人妻人伦精品1国产丝袜 | 99国产精品白浆在线观看免费 | 亚洲国产一区二区三区在线观看 | 亚洲国产精品成人久久蜜臀 | 免费看少妇作爱视频 | 日产精品99久久久久久 | 国产成人一区二区三区在线观看 | 色综合天天综合狠狠爱 | 国产午夜亚洲精品不卡 | 国精产品一品二品国精品69xx | 日韩精品a片一区二区三区妖精 | 亚洲精品www久久久 | 麻豆人妻少妇精品无码专区 | 日本丰满熟妇videos | 亚洲精品国产a久久久久久 | 偷窥村妇洗澡毛毛多 | 97资源共享在线视频 | 国产欧美精品一区二区三区 | 亚洲欧美中文字幕5发布 | 少妇厨房愉情理9仑片视频 | 国产舌乚八伦偷品w中 | 欧洲vodafone精品性 | 无码一区二区三区在线 | 精品无码成人片一区二区98 | 99久久精品国产一区二区蜜芽 | 丰满肥臀大屁股熟妇激情视频 | 国产亚av手机在线观看 | 亚洲一区二区观看播放 | 亚洲精品成人av在线 | 一本一道久久综合久久 | 无码任你躁久久久久久久 | 亚洲精品无码人妻无码 | 熟女俱乐部五十路六十路av | 欧美真人作爱免费视频 | 激情五月综合色婷婷一区二区 | 国产超级va在线观看视频 | 久久国产自偷自偷免费一区调 | 国产亚洲人成在线播放 | 亚洲精品国产a久久久久久 | 国产高清av在线播放 | 少妇久久久久久人妻无码 | 日本乱偷人妻中文字幕 | 四虎影视成人永久免费观看视频 | 亚洲精品一区二区三区大桥未久 | 免费无码的av片在线观看 | 久久人人爽人人爽人人片av高清 | 一本久久a久久精品亚洲 | 色诱久久久久综合网ywww | 亚洲精品www久久久 | 国产精品无码久久av | a国产一区二区免费入口 | a国产一区二区免费入口 | 在线 国产 欧美 亚洲 天堂 | 久久国内精品自在自线 | 激情综合激情五月俺也去 | 欧美丰满老熟妇xxxxx性 | 性色av无码免费一区二区三区 | 中国女人内谢69xxxx | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 亚洲成a人片在线观看无码3d | av在线亚洲欧洲日产一区二区 | 欧美黑人乱大交 | 久久精品人人做人人综合 | 国产性生交xxxxx无码 | 亚洲小说春色综合另类 | 麻豆人妻少妇精品无码专区 | 无码帝国www无码专区色综合 | 久久精品国产一区二区三区肥胖 | 人人妻人人澡人人爽精品欧美 | 四虎影视成人永久免费观看视频 | 免费无码午夜福利片69 | 久久亚洲精品中文字幕无男同 | 免费国产成人高清在线观看网站 | 亚洲国产精品一区二区美利坚 | 亚洲春色在线视频 | 日本精品久久久久中文字幕 | 人妻中文无码久热丝袜 | 捆绑白丝粉色jk震动捧喷白浆 | 国产国产精品人在线视 | 极品尤物被啪到呻吟喷水 | 又湿又紧又大又爽a视频国产 | 国产国语老龄妇女a片 | 两性色午夜免费视频 | 亚洲爆乳大丰满无码专区 | 人人超人人超碰超国产 | 国产高潮视频在线观看 | 高潮毛片无遮挡高清免费 | 亚洲午夜久久久影院 | 久久亚洲精品成人无码 | 日韩欧美成人免费观看 | 亚洲区欧美区综合区自拍区 | 人人妻人人澡人人爽欧美一区 | 国产色视频一区二区三区 | 18无码粉嫩小泬无套在线观看 | 国产av人人夜夜澡人人爽麻豆 | 狠狠cao日日穞夜夜穞av | 内射爽无广熟女亚洲 | 我要看www免费看插插视频 | 一本久久伊人热热精品中文字幕 | 亚洲日韩av一区二区三区中文 | 少妇的肉体aa片免费 | 欧美国产亚洲日韩在线二区 | а√资源新版在线天堂 | 无码av岛国片在线播放 | 亚洲成色在线综合网站 | 激情内射亚州一区二区三区爱妻 | 国内老熟妇对白xxxxhd | 狠狠色丁香久久婷婷综合五月 | 国产人妻精品午夜福利免费 | 色欲av亚洲一区无码少妇 | 天下第一社区视频www日本 | 亚洲人成影院在线观看 | 人妻与老人中文字幕 | 一二三四社区在线中文视频 | 亚洲成a人片在线观看日本 | 亲嘴扒胸摸屁股激烈网站 | 精品国产一区二区三区四区在线看 | 国产三级久久久精品麻豆三级 | 久久精品国产大片免费观看 | 18无码粉嫩小泬无套在线观看 | 领导边摸边吃奶边做爽在线观看 | 国产成人无码a区在线观看视频app | 久激情内射婷内射蜜桃人妖 | 老司机亚洲精品影院无码 | 亚洲 a v无 码免 费 成 人 a v | 久久国产精品精品国产色婷婷 | 亚洲成av人片在线观看无码不卡 | av无码电影一区二区三区 | 99久久精品无码一区二区毛片 | 国产热a欧美热a在线视频 | 在线观看国产午夜福利片 | 精品国产成人一区二区三区 | 日本熟妇大屁股人妻 | 久久97精品久久久久久久不卡 | 亚洲啪av永久无码精品放毛片 | 又粗又大又硬又长又爽 | 奇米影视7777久久精品 | 欧美老妇交乱视频在线观看 | 亚洲精品一区二区三区婷婷月 | 扒开双腿吃奶呻吟做受视频 |