oaid_1.0.25 调用出现NullPointerException,zlsioh.dat文件问题

1,550 阅读1分钟

作为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文件内容,如下所示:

oaid_sdk_1.0.25.png

查看应用组提供的APK文件内容,如下所示:

without_dat_apk.png

再查看我这边直接运行的APK文件内容,如下所示:

with_dat_apk.png

对比可以发现,OAID SDK的classes.jar/assets/zlsioh.dat文件,在应用组的APK里面并没有被集成,后来问了一下应用组的集成方式,他们并不是直接依赖集成的,而是注入的方式,具体怎么操作没有说,导致丢失了这一文件。

这个问题,可以把zlsioh.dat文件抽离出来,和supplierconfig.json一起放在assets文件夹里面给到应用组集成,重新打包后能够正常运行。

至此,问题得到解决。