作为SDK开发组封装获取OAID内容SDK,然后提供给应用组使用,结果应用运行出现以下问题:
System.err: java.lang.reflect.InvocationTargetException
System.err: at java.lang.reflect.Method.invoke(Native Method)
System.err: at com.xxx.xxx.utils.Util$1.run(Util.java:107)
System.err: at android.os.Handler.handleCallback(Handler.java:873)
System.err: at android.os.Handler.dispatchMessage(Handler.java:99)
System.err: at android.os.Looper.loop(Looper.java:201)
System.err: at android.app.ActivityThread.main(ActivityThread.java:6806)
System.err: at java.lang.reflect.Method.invoke(Native Method)
System.err: at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:547)
System.err: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:873)
System.err: Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'int java.lang.Integer.intValue()' on a null object reference
System.err: at com.bun.miitmdid.core.MdidSdkHelper.InitSdk(Unknown Source:43)
一开始以为是SDK封装的问题,于是在获取OAID的地方添加异常捕获,重新打包提供给应用组运行发现还是报错。仔细查看报错信息发现在OAID SDK内部就已经出现异常了,但是我这边直接运行又不会出现这个异常。
于是查看OAID SDK文件内容,如下所示:
查看应用组提供的APK文件内容,如下所示:
再查看我这边直接运行的APK文件内容,如下所示:
对比可以发现,OAID SDK的classes.jar/assets/zlsioh.dat
文件,在应用组的APK里面并没有被集成,后来问了一下应用组的集成方式,他们并不是直接依赖集成的,而是注入的方式,具体怎么操作没有说,导致丢失了这一文件。
这个问题,可以把zlsioh.dat
文件抽离出来,和supplierconfig.json
一起放在assets
文件夹里面给到应用组集成,重新打包后能够正常运行。
至此,问题得到解决。