Android 9.0系统不允许Http协议访问网络突破

原因:

Google表示,为保证用户数据和设备的安全,针对下一代 Android 系统(Android P(9.0)) 的应用程序,将要求默认使用加密连接,这意味着 Android P(9.0) 将禁止 App 使用所有未加密的连接,因此运行 Android P(9.0) 系统的安卓设备无论是接收或者发送流量,未来都不能明码传输,需要使用下一代(Transport Layer Security)传输层安全协议,而 Android Nougat 和 Oreo 则不受影响。

因此在Android P(9.0) 使用HttpUrlConnection进行http请求会出现以下异常:

W/System.err: java.io.IOException: Cleartext HTTP traffic to ** not permitted

使用OKHttp请求会出现:

java.net.UnknownServiceException: CLEARTEXT communication ** not permitted by network security policy

 意思大概就是:安全策略不允许进行明文通讯

在Android P(9.0)系统的设备上,如果应用使用的是非加密的明文流量的http网络请求,则会导致该应用无法进行网络请求,https则不会受影响,如果应用嵌套了webview,webview也只能使用https请求。无法使用http请求,有人认为 Android P(9.0)上所有的 App 都需要使用 TLS 加密会降低上网体验,个人觉得上这是一种误解,对于一些老旧非要使用http协议的服务器我们可以采取配置APP的联网策略方式进行限制突破

解决方案如下:

一:

在Mainfiests,直接在application标签下配置如下代码

<uses-library
            android:name="org.apache.http.legacy"
            android:required="false" />

二:

targetSdkVersion 降到27以下

三:

在 res 下新建一个xml目录,然后创建一个名为:network_config.xml 文件(名字自定),内容如下

<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
    <base-config cleartextTrafficPermitted="true" />
</network-security-config>

在Mainfiests  appliction标签下配置该属性

 android:networkSecurityConfig="@xml/network_config"

即可解决,9.0系统不允许Http协议访问网络的限制。

  • 6
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android 9.0 系统中,为了提高设备的安全性,禁止了默认情况下安装未知来源应用程序的权限。然而,我们可以通过编写代码来实现动态请求并获取该权限。 首先,在 AndroidManifest.xml 文件中添加以下权限: ```xml <uses-permission android:name="android.permission.REQUEST_INSTALL_PACKAGES"/> ``` 然后,在你的应用程序中创建一个方法来请求安装未知来源应用程序的权限: ```java private void requestInstallUnknownAppsPermission() { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { // 判断当前 Android 版本是否高于等于 Android 8.0 if (!getPackageManager().canRequestPackageInstalls()) { // 如果没有权限,跳转到权限设置页面 Intent intent = new Intent(Settings.ACTION_MANAGE_UNKNOWN_APP_SOURCES); intent.setData(Uri.parse("package:" + getPackageName())); startActivityForResult(intent, 1); } } } ``` 在该方法中,我们首先检查设备上的 Android 版本是否高于等于 Android 8.0,然后判断是否已经获得了安装未知来源应用程序的权限。如果没有权限,我们将启动一个意图(Intent)并跳转到权限设置页面,允许用户手动开启该权限。 最后,在你的代码中的适当位置调用该方法: ```java requestInstallUnknownAppsPermission(); ``` 这样一来,每当用户安装你的应用程序时,都会自动检查并请求安装未知来源应用程序的权限,如果没有权限则会跳转到权限设置页面,让用户手动开启。 注意:为了使这些代码生效,你需要确保你的应用程序具有 WRITE_EXTERNAL_STORAGE 权限,这样才能正常安装来自未知来源的应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值