Android开发问题排查:CLEARTEXT communication错误的处理和避免

简介: 综上,我们可以说要避免CLEARTEXT通信错误的最佳办法是使用HTTPS,但在实践中遇到某些无法支持HTTPS的API,我们也可以通过配置Network security configuration文件来跳过系统的安全检查。安全和实用性需两者都顾及,明智地选择你的道路,战胜那些阻挡你的小怪兽吧!"

"清明明朗的天空,突然被一片乌云遮挡,未加密的HTTP请求像冷雨,照进Android App开发者的心头。这就是Android P以后的版本,在尝试进行CLEARTEXT(明文)通信时,会遇到的一种错误。如果你是Android V9以后的版本的开发者,那么你就必须面对这个一个越来越常见的问题:CLEARTEXT communication错误。

说到CLEARTEXT communication错误,它就像是黑暗中的“食人花”。为什么这样说?因为它的存在,犹如暗夜中的小怪兽,突然出现在你所期待的结果之前。你一头撞进了Android操作系统的安全政策,让你的App在试图发送未加密的网络请求时崩溃。

所以怎样才能打败这个小怪兽呢?

首先,我们来了解一下这个小怪兽的“家族”。从Android 9(Pie)开始,为增加用户数据的安全性,默认情况下,操作系统会阻止App通过明文进行网络传输。这个设定可以在App的Manifest文件的application标签下加入 android:usesCleartextTraffic=“true” 参数进行修改,但这样可能会导致应用数据的安全问题。

那要如何选择最好的武器来打败这个小怪兽呢?答案是SSL/TLS。它们是https的基础,可以将你的数据加密,使网络间的传输变得安全。而为了实现这个,你需要将网络连接协议由http改为https,这样一来你将不再遭受CLEARTEXT communication错误的困扰。

具体实现起来,就是将请求的 URL 中的 http 部分替换为 https,例如,http://example.com应改为https://example.com

然而,黑暗中的怪兽总是有它的兄弟姐妹,当你发现你使用的第三方API无法提供https链接时,你又该如何战斗呢?这时候你需要创建一个Network security configuration文件,然后将允许清文传输的域名加入。具体步骤如下:

步骤1:在res目录下创建一个xml文件夹,并在该文件夹下创建一个network_security_config.xml文件。

步骤2:在network_security_config.xml文件中写入如下内容:

<network-security-config> 
    <domain-config cleartextTrafficPermitted="true"> 
        <domain includeSubdomains="true">不支持https的域名</domain>
    </domain-config> 
</network-security-config>
​

步骤3:在AndroidManifest.xml中的application标签中添加如下代码:

<application
...
android:networkSecurityConfig="@xml/network_security_config"
...
</application>
​

通过以上操作,你就等于是找到了一个光明的路标,将允许CLEARTEXT通信的域名排除在安全检查范围,这样你就能继续你的旅程了。

当然,你要知道,防止CLEARTEXT communication错误的最佳方法还是尽可能使用https进行网络通信。毕竟,在这个数据安全问题日益重要的现今,加密通信己经成为一个标准,做为Android开发者,我们也应对这个转变有所准备。

综上,我们可以说要避免CLEARTEXT通信错误的最佳办法是使用HTTPS,但在实践中遇到某些无法支持HTTPS的API,我们也可以通过配置Network security configuration文件来跳过系统的安全检查。安全和实用性需两者都顾及,明智地选择你的道路,战胜那些阻挡你的小怪兽吧!"

目录
相关文章
|
Java Android开发 开发者
1024程序节|Android框架之一 BRVAH【BaseRecyclerViewAdapterHelper】使用demo
BRVAH是一个强大的RecyclerAdapter框架(什么是RecyclerView?),它能节约开发者大量的开发时间,集成了大部分列表常用需求解决方案。为什么会有它?请查看「Android开源框架BRVAH由来篇」该框架于2016年4月10号发布的第1个版本到现在已经一年多了,经历了800多次代码提交,140多次版本打包,修复了1000多个问题,获得了9000多star,非常感谢大家的使用以及反馈。
469 0
|
XML Java 数据库
安卓项目:app注册/登录界面设计
本文介绍了如何设计一个Android应用的注册/登录界面,包括布局文件的创建、登录和注册逻辑的实现,以及运行效果的展示。
801 1
安卓项目:app注册/登录界面设计
|
XML JSON Java
Android App网络通信中通过okhttp调用HTTP接口讲解及实战(包括GET、表单格式POST、JSON格式POST 附源码)
Android App网络通信中通过okhttp调用HTTP接口讲解及实战(包括GET、表单格式POST、JSON格式POST 附源码)
2012 0
|
存储 缓存 JavaScript
Flutter笔记:关于WebView插件的用法(上)
Flutter笔记:关于WebView插件的用法(上)
4097 5
|
缓存 负载均衡 测试技术
企业系统工程(Enterprise Systems Engineering, ESE)是一个跨学科的领域,它应用系统工程的原则和方法来规划、设计、实施和管理复杂的组织系统,特别是那些涉及信息技术(IT)和商业流程的系统。
企业系统工程(Enterprise Systems Engineering, ESE)是一个跨学科的领域,它应用系统工程的原则和方法来规划、设计、实施和管理复杂的组织系统,特别是那些涉及信息技术(IT)和商业流程的系统。
|
Android开发
Android studio 出现Plugin [id: ‘com.android.application‘, version: ‘8.1.0‘, apply: false] 问题解决办法
Android studio 出现Plugin [id: ‘com.android.application‘, version: ‘8.1.0‘, apply: false] 问题解决办法
5986 2
|
网络架构
网络割接,用VRRP替换HSRP,你得这么割才行!
网络割接,用VRRP替换HSRP,你得这么割才行!
257 0
|
缓存 算法 NoSQL
短信验证码登录接口,如何防止恶意攻击
该文讨论了移动应用中常见的手机短信验证码登录方式,后端实现通常涉及两个API:获取短信验证码和短信验证码登录。在设计时,为增强短信验证码接口的安全性,提出了几种无需使用Redis等存储介质的方案:1) 使用数字签名,基于时间戳或随机数生成唯一签名进行验证;2) 基于时间的有效期验证,通过加密或修改时间戳形式确保安全性;3) 应用TOTP算法,按时间生成动态码进行比对;4) 利用JWTToken生成带有限期的签名进行验证。这些方法旨在防止恶意攻击并优化登录接口性能。
750 1
后端测试------使用Postman统一添加请求头
后端测试------使用Postman统一添加请求头
|
编译器 Android开发 开发者
深入理解 Android 模块化里的资源冲突
深入理解 Android 模块化里的资源冲突
深入理解 Android 模块化里的资源冲突