前言:爲保證用戶數據和設備的安全,Google針對下一代 Android 系統(Android P) 的應用程序,將要求默認使用加密鏈接,這意味着 Android P 將禁止 App 使用全部未加密的鏈接,所以運行 Android P 系統的安卓設備不管是接收或者發送流量,將來都不能明碼傳輸,須要使用下一代(Transport Layer Security)傳輸層安全協議,而 Android Nougat 和 Oreo 則不受影響。java
所以在Android P 使用HttpUrlConnection進行http請求會出現如下異常android
W/System.err: java.io.IOException: Cleartext HTTP traffic to **** not permitted
使用OKHttp請求則出現web
java.net.UnknownServiceException: CLEARTEXT communication ** not permitted by network security policy
在Android P系統的設備上,若是應用使用的是非加密的明文流量的http網絡請求,則會致使該應用沒法進行網絡請求,https則不會受影響,一樣地,若是應用嵌套了webview,webview也只能使用https請求。安全
針對這個問題,有如下三種解決方法:網絡
(1)APP改用https請求app
(2)targetSdkVersion 降到27如下加密
(3)更改網絡安全配置.net
前面兩個方法容易理解和實現,具體說說第三種方法,更改網絡安全配置。xml
1.在res文件夾下建立一個xml文件夾,而後建立一個network_security_config.xml文件,文件內容以下:網絡安全
<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
<base-config cleartextTrafficPermitted="true" />
</network-security-config>
2.接着,在AndroidManifest.xml文件下的application標籤增長如下屬性:
<application ... android:networkSecurityConfig="@xml/network_security_config" ... /> 完成,這個時候App就能夠訪問網絡了。