本文节选自洪流学堂公众号技术专栏《大话Unity2019》,未经允许不可转载。
洪流学堂公众号回复log
,获取最新版运行时查看日志的工具。
小新:“最近我升级到Android API Level 28之后,发现发布的安卓包,网络请求都不通了,这是咋回事啊?”
大智:“遇到这种问题,调试的时候首先去看日志,你研究运行日志了么?”
小新:“哎呀,我给忘了。不过,在Unity中我知道在Console面板上看日志,已经发布出来在手机上运行的程序怎么看日志啊?”
大智:“看来得先学习怎么看日志。”
查看运行在Android真机程序的日志有几种办法:
adb logcat
通过USB或者局域网连接都可。
adb logcat
使用命令行工具adb logcat
或者使用AndroidStudio对应的工具。
有一个神器,可以在运行时查看Unity的日志,到洪流学堂公众号回复log
获取最新版吧!
小新:“哎,真的找到问题了!错误提示是这样的:”
Cleartext HTTP traffic to xxx not permitted
大智:“好了,现在有关键词了,你可以自己求助搜索引擎了吧?”
小新:“嗯嗯,知道调试的方法太重要啦!”
大智:“找到解决办法以后,记得给大家分享一下哦。”
Android系统出于安全性考虑,在Android P系统(Android API >= 28)的设备上,如果应用使用的是非加密的明文流量的http网络请求,则会导致该应用无法进行网络请求,https则不会受影响;同样的,如果应用嵌套了webview,webview也只能使用https请求。
解决办法有几种:
在可信任的证书厂商申请SSL证书,给服务端配置。
大智常用的申请证书的地方:
https://freessl.cn/
先在菜单栏:File > Build Settings中切换平台为Android,Player Settings中Other Settings中Identification中的Target API Level设置为27。
在Unity工程中的AndroidManifest.xml文件中增加支持明文请求:
android:usesCleartextTraffic="true"
创建一个文件放到Assets/Plugins/Android/AndroidManifest.xml
大智:“解决这种问题,首先要从表象找到原因,这个过程一般都是从log信息中发掘线索。”
洪流学堂公众号回复log
获取最新版运行时查看日志的工具。
洪流学堂公众号回复log
获取最新版运行时查看日志的工具。
《大话Unity2019》,大智带小新学Unity2019的有趣经历,让你学Unity更简单。