记一次 报错:Android ClassNotFoundException: Didn't find class on path

场景

项目上线后,用户反馈,安装完打开应用就显示“应用已停止运行”,改错误发生在5.0以上的手机,经测试6.7.8.均没有问题,推测是6.0以下会有这个问题。调试时,报错如下:
记一次 报错:Android ClassNotFoundException: Didn't find class on path
提示类找不到,检查了AndroidManifest.xml 都没问题,在网上搜了一圈,大多都是采用分包解决,然而项目本来就是采用的分包multiDexEnabled true,还有删除build文件夹的,这些都试过..
经测试,debug包是没有问题的,只有打包后会出现,问题定位在打包配置上,检查build.gradle如下图
记一次 报错:Android ClassNotFoundException: Didn't find class on path

项目原先是没有添加v2SigningEnabled true

解决

signingConfigs 里添加配置v2SigningEnabled true 或者使用AS自带的打包,勾选v2
记一次 报错:Android ClassNotFoundException: Didn't find class on path

深入

  • v1和v2的签名使用
    1)只勾选v1签名并不会影响什么,但是在7.0上不会使用更安全的验证方式
    2)只勾选V2签名7.0以下会直接安装完显示未安装,7.0以上则使用了V2的方式验证
    3)同时勾选V1和V2则所有机型都没问题

  • Android 7.0中引入了APK Signature Scheme v2,v1是jar Signature来自JDK
    V1:应该是通过ZIP条目进行验证,这样APK 签署后可进行许多修改 - 可以移动甚至重新压缩文件。
    V2:验证压缩文件的所有字节,而不是单个 ZIP 条目,因此,在签名后无法再更改(包括 zipalign)。正因如此,现在在编译过程中,我们将压缩、调整和签署合并成一步完成。好处显而易见,更安全而且新的签名可缩短在设备上进行验证的时间(不需要费时地解压缩然后验证),从而加快应用安装速度。

参考资料:
+ Android Studio 打包时 Signature Version 选择 V1 V2 说明
+ Android 分包导致低于5.0版本报错ClassNotFoundException