Android getParcelableExtra传入畸形数据导致APP崩溃Crash复现及原因分析

Posted WillWinwin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android getParcelableExtra传入畸形数据导致APP崩溃Crash复现及原因分析相关的知识,希望对你有一定的参考价值。

android getParcelableExtra传入畸形数据导致APP崩溃Crash复现及原因分析

Crash复现

APP A


创建了一个Text类来实现Parcelable接口,然后使用getParcelableExtra直接获取intent传参。
Text如下,详细可下载apk反编译查看:

package com.example.myapplication;

import android.os.Parcel;
import android.os.Parcelable;

public class Text implements Parcelable 
    private String string = "hello,cb";

    public Text() 
        setString("hello,cb");
    

    public Text(Parcel parcel) 
        setString(parcel.readString());
    

    public static final Parcelable.Creator<Text> CREATOR = new Parcelable.Creator<Text>() 

        public Text createFromParcel(Parcel source) 
            return new Text(source);
        

        public Text[] newArray(int size) 
            return new Text[size];
        
    ;

    public String getString() 
        return string;
    

    public void setString(String string) 
        this.string = string;
    

    public int describeContents() 
        return 0;
    

    public void writeToParcel(Parcel dest, int flags) 
        dest.writeString(string);
    


APP B

APP B用于发送intent消息给APP A

其中也创建了一个Text2来实现Parcelable接口,其中并未实现具体内容,这里不贴代码,详细可以通过jadx反编译apk即可看到。

复现现象


从上图可以看到,报错信息为
2020-04-11 21:43:50.938 7922-7922/com.example.myapplication E/Parcel: Class not found when unmarshalling: com.example.myapplication2.Text2
java.lang.ClassNotFoundException: com.example.myapplication2.Text2
at java.lang.Class.classForName(Native Method)

对于getParcelableExtra或者getSerilizableExtra相关的方法,如果没有使用try-catch捕获异常的话,都存在上述问题。

问题原因分析

当解析到Serializable对象时,由于加载不到类,抛出异常

public final Serializable readSerializable()   
    ...  
    try   
        ObjectInputStream ois = new ObjectInputStream(bais);  
        return (Serializable) ois.readObject();  
     catch (IOException ioe)   
        throw new RuntimeException("Parcelable encountered " + "IOException reading a Serializable object (name = " + name +  ")", ioe);  
     catch (ClassNotFoundException cnfe)   
        throw new RuntimeException("Parcelable encountered" + "ClassNotFoundException reading a Serializable object (name = " + name + ")", cnfe);  
      

链接:demo apk
提取码:hawr

参考

Android APP通用型拒绝服务漏洞分析报告
android之Parcel机制学习

以上是关于Android getParcelableExtra传入畸形数据导致APP崩溃Crash复现及原因分析的主要内容,如果未能解决你的问题,请参考以下文章

Android 逆向Android 权限 ( Android 逆向中使用的 android.permission 权限 | Android 系统中的 Linux 用户权限 )

android 21 是啥版本

Android逆向-Android基础逆向(2-2)

【Android笔记】android Toast

图解Android - Android核心机制

Android游戏开发大全的目录