在修改targetsdk为28后,在请求非https的网络地址时报错
内容:CLEARTEXT communication to host not permitted by network
原因:非加密的流量请求都会被系统禁止掉
Android 9 包含可提升您的应用安全性的多个行为变更,但这些变更仅在您的应用以 API 级别 28 或更高级别为目标平台时才会生效,默认情况下启用网络传输层安全协议 (TLS)
如果您的应用以 Android 9 或更高版本为目标平台,则默认情况下isCleartextTrafficPermitted()函数返回false。 如果您的应用需要为特定域名启用明文,您必须在应用的网络安全性配置中针对这些域名将cleartextTrafficPermitted显式设置为true。
方式1
在res下新建xml文件夹,然后创建一个security_config.xml的文件(name可自由命名),文件内容如下:
<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
<base-config cleartextTrafficPermitted="true" />
</network-security-config>
接着在清单文件中的application节点下添加代码:android:networkSecurityConfig="@xml/name.xml"(上述新建文件的名字)
方式2
设置application的android:usesCleartextTraffic为"true"。
源码解析:
android.content.pm.PackageParser.parseBaseApplication
if(sa.getBoolean( com.android.internal.R.styleable.AndroidManifestApplication_usesCleartextTraffic, owner.applicationInfo.targetSdkVersion < Build.VERSION_CODES.P))
{
ai.flags |= ApplicationInfo.FLAG_USES_CLEARTEXT_TRAFFIC;
}
网友评论