Android高版本聯(lián)網(wǎng)失敗報錯:Cleartext HTTP traffic to xxx not permitted解決方法

前言:為保證用戶數(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標簽增加以下屬性:

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

完成,這個時候App就可以訪問網(wǎng)絡(luò)了。

作者:柚子君.
來源:CSDN
原文:https://blog.csdn.net/gengkui9897/article/details/82863966

以上,是轉(zhuǎn)載的,重新排了版,顯示好看點了

他的報錯原因?qū)懙暮芎门叮旅娴氖俏姨幚淼姆椒?/h3>

其實,第三種方式,可以直接在清單文件中的application中添加

      android:usesCleartextTraffic="true"

即可

如圖~


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容