最近将targetSdkVersion
升级为28
了,升级之后在Android 9.0
及以上系统中,发生了一些兼容性问题,现在把实际项目中碰到的问题总结如下:
1. HTTP请求被禁止
碰到的第一个问题就是,发现在 Android 9.0 系统的手机中,所有 http 的接口或链接都无法访问了,但是在 9.0 以下的系统中是没有这个问题的。经过查阅资料,原因是早在 6.0 系统时,Android 就引入了对 https 的推荐支持,从 9.0 系统开始,默认所有的 http 请求都被认为是不安全的请求,全被系统阻止了。解决方案有2种:
- 全部切换为 https,不过目前看起来不太现实,因为 app 里除了本公司的 http 请求外,可能会对接很多第三方服务,对应第三方的东西我们无法控制;
- 在 AndroidManifest.xml 的 application 里增加配置
android:usesCleartextTraffic="true"
,强制允许使用 http 请求,这是推荐的做法;
2. EditText 不会自动获取焦点
在 9.0 中我们发现好多页面的输入框,在页面进入时,不会自动获得焦点,必须手动点击一下输入框,该输入框才会获得焦点。这个特别影响用户体验,特别是像注册登录页面,页面进入后我们都是自动弹出输入法,用户可以直接输入文本。但是现在是软键盘虽然可能弹出了,但是没有任何一个输入框获得焦点,也无法直接输入文本了。
后来找到原因是:9.0开始不再隐式分配触摸模式下的初始焦点。
也就是说在 9.0 以前的系统中,如果一个页面中有类似 EditText 之类的输入框存在的话,Activity 打开时会默认将焦点分配在第一个 EditText 上,但是现在则不会了,你必须通过代码手动请求初始焦点(如果需要的话)。
EditText et;
et.requestFocus()
3. Apache HttpClient 被弃用
这是从 bugly 上看到的一个错误:
java.lang.NoClassDefFoundError:Failed resolution of: Lorg/apache/http/conn/scheme/SchemeRegistry;
com.tencent.open.utils.HttpUtils.getHttpClient(ProGuard:626)
......
Caused by:
java.lang.ClassNotFoundException:Didn't find class "org.apache.http.conn.scheme.SchemeRegistry"
从网上找到的资料说:从 6.0 开始 sdk 就已经移除了 HttpClient 相关的 api,从 9.0 开始 org.apache.http.legacy
库将从 bootclasspath
中删除。说实话,还在用 HttpClient 的也是老古董的产品了,现在谁不用 OkHttp 呢。但是上面这个错误,我们发现是在 9.0 系统的手机上,通过腾讯QQ分享时引起的一个闪退。这真的是很蛋疼的事情,腾讯QQ的分享 SDK 居然有用到 HttpClient 的东西,目前我们又不能把它剔除掉,那怎么解决呢,幸好还有办法:
<application>
<uses-library
android:name="org.apache.http.legacy"
android:required="false" />
</application>
后面可能还会碰到更多的问题,持续更新中...