action请求_Unity中Android API 28之后无法HTTP请求

c3ce0ca37aa208a5eaceae35d92d26dd.png
本文节选自 洪流学堂公众号技术专栏《大话Unity2019》,未经允许不可转载。

洪流学堂公众号回复log,获取最新版运行时查看日志的工具。


小新:“最近我升级到Android API Level 28之后,发现发布的安卓包,网络请求都不通了,这是咋回事啊?”

大智:“遇到这种问题,调试的时候首先去看日志,你研究运行日志了么?”

小新:“哎呀,我给忘了。不过,在Unity中我知道在Console面板上看日志,已经发布出来在手机上运行的程序怎么看日志啊?”

大智:“看来得先学习怎么看日志。”

Unity Android查看日志

查看运行在Android真机程序的日志有几种办法: - 2019.1之后可以直接在Unity编辑器中连接到手机查看运行的日志 - 使用Android开发者工具的adb logcat - 使用Unity的运行时日志查看插件

方法1:2019.1之后可以直接在Unity编辑器中连接到手机查看运行的日志

通过USB或者局域网连接都可。

6a0cd34d0098b777a66215c3422a6269.png

方法2:使用Android开发者工具的adb logcat

使用命令行工具adb logcat或者使用AndroidStudio对应的工具。

方法3:使用Unity的运行时日志查看插件

有一个神器,可以在运行时查看Unity的日志,到洪流学堂公众号回复log获取最新版吧!

Unity中Android API 28之后无法HTTP请求

小新:“哎,真的找到问题了!错误提示是这样的:”

Cleartext HTTP traffic to xxx not permitted

大智:“好了,现在有关键词了,你可以自己求助搜索引擎了吧?”

小新:“嗯嗯,知道调试的方法太重要啦!”

大智:“找到解决办法以后,记得给大家分享一下哦。”

问题原因

Android系统出于安全性考虑,在Android P系统(Android API >= 28)的设备上,如果应用使用的是非加密的明文流量的http网络请求,则会导致该应用无法进行网络请求,https则不会受影响;同样的,如果应用嵌套了webview,webview也只能使用https请求。

解决办法

解决办法有几种: - 配置好服务端的SSL证书,客户端使用HTTPS请求 - API版本使用27及以下的版本 - 配置客户端允许不安全的HTTP请求

方法1:配置好服务端的SSL证书,客户端使用HTTPS请求

在可信任的证书厂商申请SSL证书,给服务端配置。

大智常用的申请证书的地方: https://freessl.cn/

方法2:配置Android API为27版本

先在菜单栏:File > Build Settings中切换平台为Android,Player Settings中Other Settings中Identification中的Target API Level设置为27。

方法3:配置客户端允许不安全的HTTP请求

在Unity工程中的AndroidManifest.xml文件中增加支持明文请求:

android:usesCleartextTraffic="true"

创建一个文件放到Assets/Plugins/Android/AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="PACKAGE"
      android:versionCode="1"
      android:versionName="1.0">
    <application android:usesCleartextTraffic="true" android:label="@string/app_name" ICON>
        <activity android:name="ACTIVITY_ENTRY_NAME"
                  android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>
</manifest>

总结

大智:“解决这种问题,首先要从表象找到原因,这个过程一般都是从log信息中发掘线索。”

2cecfa197cb746201b83c1a419aa376c.png
https://www.zhihu.com/video/1112746036115894272

洪流学堂公众号回复log获取最新版运行时查看日志的工具。

推荐阅读

  • Unity 2019.1 中文更新日志速览版
  • Unity开发《一起来捉妖》教程 | 1.陀螺仪控制相机
  • Unity开发《一起来捉妖》教程 | 2.用摄像头图像做背景
  • Unity中的HTTP通信
  • UnityWebRequest详解
  • Unity中编码Encoding脱坑指南
  • Unity中的Git最佳实践
  • Unity2019更新规划速览,将有官方的可视化编程!
  • Unity运行时更新带来了什么?
  • Unity2018.3新功能 | Prefab嵌套和变体

洪流学堂公众号回复log获取最新版运行时查看日志的工具。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值