一次混淆XLog导致的crash分析记录

crash报错内容如下。

yaml 复制代码
08-27 00:04:36.844 18272 18272 E AndroidRuntime: FATAL EXCEPTION: main
08-27 00:04:36.844 18272 18272 E AndroidRuntime: Process: com.XXX.XXXX, PID: 18272
08-27 00:04:36.844 18272 18272 E AndroidRuntime: java.lang.UnsatisfiedLinkError: field:level, sig:I
...
08-27 00:04:36.844 18272 18272 E AndroidRuntime:    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2168)
08-27 00:04:36.844 18272 18272 E AndroidRuntime:    at android.os.Handler.dispatchMessage(Handler.java:106)
08-27 00:04:36.844 18272 18272 E AndroidRuntime:    at android.os.Looper.loopOnce(Looper.java:222)
08-27 00:04:36.844 18272 18272 E AndroidRuntime:    at android.os.Looper.loop(Looper.java:319)
08-27 00:04:36.844 18272 18272 E AndroidRuntime:    at android.app.ActivityThread.main(ActivityThread.java:8189)
08-27 00:04:36.844 18272 18272 E AndroidRuntime:    at java.lang.reflect.Method.invoke(Native Method)
08-27 00:04:36.844 18272 18272 E AndroidRuntime:    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:583)
08-27 00:04:36.844 18272 18272 E AndroidRuntime:    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1013)

在Tencent的Xlog库搜索关键字appenderOpen,可以定位到问题代码所在。

ini 复制代码
JNIEXPORT void JNICALL Java_com_tencent_mars_xlog_Xlog_appenderOpen(JNIEnv* env, jclass clazz, jobject _log_config) {
    if (NULL == _log_config) {
        xerror2(TSF "logconfig is null");
        return;
    }

    jint level = JNU_GetField(env, _log_config, "level", "I").i;
    
    ...
}

结合crash信息可知_log_config的level字段找不到了,下面是该native方法在java中的声明。

java 复制代码
private static native void appenderOpen(XLogConfig logConfig);

结合两段代码知道_log_config对应着的应该是XLogConfig类。

怀疑是代码进行了混淆导致的。

把Jenkins上打的APK拉下来,使用Jadx软件进行解析,搜索XLogConfig。

可以看到被混淆后的XLogConfig类中确实没有level字段,而混淆前的代码里是有的。

arduino 复制代码
//混淆前的代码
static class XLoggerInfo {
    public int level;
    public String tag;
    public String filename;
    public String funcname;
    public int line;
    public long pid;
    public long tid;
    public long maintid;
}

因此解决办法也很简单,把Tencent的Xlog库配置为不混淆即可。

相关推荐
用户69371750013841 天前
Google 正在“收紧侧加载”:陌生 APK 安装或需等待 24 小时
android·前端
用户69371750013841 天前
Room 3.0:这次不是升级,是重来
android·前端·google
alexhilton1 天前
Compose中的ContentScale:终极可视化指南
android·kotlin·android jetpack
Digitally1 天前
2026 年 8 款安卓数据擦除软件和应用对比
android
杨忆1 天前
android 11以上 截图工具类
android
粤M温同学1 天前
Android Studio 中安装 CodeBuddy AI助手
android·ide·android studio
阿拉斯攀登1 天前
【RK3576 安卓 JNI/NDK 系列 08】RK3576 实战(二):JNI 调用 I2C 驱动读取传感器数据
android·安卓ndk入门·jni方法签名·java调用c++·rk3576底层开发·rk3576 i2c开发
赶路人儿1 天前
常见的mcp配置
android·adb
符哥20081 天前
充电桩 WiFi 局域网配网(Android/Kotlin)流程、指令及实例说明文档
android·开发语言·kotlin
没有了遇见1 天前
Android 项目架构之<用户信息模块>
android