為保證用戶數(shù)據(jù)和設(shè)備的安全嗤形,Google針對下一代 Android 系統(tǒng)(Android P) 的應(yīng)用程序,將要求默認使用加密連接弧圆,這意味著 Android P 將禁止 App 使用所有未加密的連接赋兵,因此運行 Android P 系統(tǒng)的安卓設(shè)備無論是接收或者發(fā)送流量,未來都不能明碼傳輸搔预,需要使用下一代(Transport Layer Security)傳輸層安全協(xié)議霹期,而 Android Nougat 和 Oreo 則不受影響。
因此在Android P 使用HttpUrlConnection進行http請求會出現(xiàn)以下異常
W/System.err: java.io.IOException: Cleartext HTTP traffic to **** not permitted
使用OKHttp請求則出現(xiàn)
java.net.UnknownServiceException: CLEARTEXT communication ** not permitted by network security policy
在Android P系統(tǒng)的設(shè)備上拯田,如果應(yīng)用使用的是非加密的明文流量的http網(wǎng)絡(luò)請求历造,則會導(dǎo)致該應(yīng)用無法進行網(wǎng)絡(luò)請求,https則不會受影響船庇,同樣地吭产,如果應(yīng)用嵌套了webview,webview也只能使用https請求鸭轮。
針對這個問題臣淤,有以下三種解決方法:
(1)APP改用https請求
(2)targetSdkVersion 降到27以下
(3)更改網(wǎng)絡(luò)安全配置
前面兩個方法容易理解和實現(xiàn),具體說說第三種方法窃爷,更改網(wǎng)絡(luò)安全配置邑蒋。
1.在res文件夾下創(chuàng)建一個xml文件夾,然后創(chuàng)建一個network_security_config.xml文件吞鸭,文件內(nèi)容如下:
<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
<base-config cleartextTrafficPermitted="true" />
</network-security-config>
2.接著,在AndroidManifest.xml文件下的application標(biāo)簽增加以下屬性:
<application
...
android:networkSecurityConfig="@xml/network_security_config"
...
/>
完成覆糟,這個時候App就可以訪問網(wǎng)絡(luò)了刻剥。
轉(zhuǎn)載自:https://blog.csdn.net/gengkui9897/article/details/82863966