用log4j写了个收集日志的小工具,在6.0的设备上可以正常搜集日志,换了10.0的设备就报错了,断点看了下是在logConfigurator.configure()的时候报的错:Exception configuring log system。
解决方法:
在AndroidManifest.xml文件中application节点中加上android:requestLegacyExternalStorage="true"属性就可以了,如下:
<application
android:requestLegacyExternalStorage="true"
出错的原因是我把日志放到Environment.getExternalStorageDirectory()下面了,但是在Android10(API 29)以后这个路径是没有权限访问的,无论你在AndroidManifest.xml文件中加上对应的权限还是使用ActivityCompat.requestPermissions动态申请到权限还是没有解决!最后参考的官方文档解决的。
参考官方文档: https://developer.android.google.cn/training/data-storage/compatibility
发现按上面的方法进行修改后,在公司定制的一款pad上(10.0)还是无法把log存储到根目录,无奈只能把路径改为context.getExternalFilesDir()了,之前不想用这个路径是因为首先找起来路径比较深,再者卸载应用后会把log删掉,测试有的时候会卸载重装,用这个也是无奈之举啊,如果同学们有在10.0及以上版本存储日志的好办法,欢迎留言告诉一下,不胜感激。