Android targetSdkVersion升级到28在9.0系统遇到的问题

最近将targetSdkVersion升级为28了,升级之后在Android 9.0及以上系统中,发生了一些兼容性问题,现在把实际项目中碰到的问题总结如下:

1. HTTP请求被禁止

碰到的第一个问题就是,发现在 Android 9.0 系统的手机中,所有 http 的接口或链接都无法访问了,但是在 9.0 以下的系统中是没有这个问题的。经过查阅资料,原因是早在 6.0 系统时,Android 就引入了对 https 的推荐支持,从 9.0 系统开始,默认所有的 http 请求都被认为是不安全的请求,全被系统阻止了。解决方案有2种:

  1. 全部切换为 https,不过目前看起来不太现实,因为 app 里除了本公司的 http 请求外,可能会对接很多第三方服务,对应第三方的东西我们无法控制;
  2. 在 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>        

后面可能还会碰到更多的问题,持续更新中...

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容