7

我有一个使用 applinks的游戏。从我的计算机运行调试和发布版本时,应用链接工作正常,但不适用于从 Google Play 下载的版本。使用 Google Play 版本时,我会收到一个对话框,询问应该打开链接的应用程序。

我使用“App Signing by Google Play”并了解发布 APK 由 Google 签名并且具有不同的签名。我已将 Google Play 上列出的应用签名证书中的 SHA-256 证书指纹添加到我的assetslinks.json中,因此它包含来自本地和 Google Play 版本的指纹。

我还从 Google Play 下载了一个派生的 APK,并确保指纹与assetlinks.json 文件中的指纹匹配。

这是一个示例 URL,当在 Android 中单击该 URL 时,应打开应用程序,它适用于本地构建,但在 Google Play 版本中不会。相反,我得到一个对话框,询问哪个应用程序应该打开链接。

https://letsdraw.fun/ec?parent=Z0ibN7m-H8jO1jCiMRQtY23VTpKjnIch

我正在从实时发布版本的 logcat 中写出 SHA256 指纹,以仔细检查它是否正确,一切看起来都很好。

原始签名 APK 和 Google Play 签名 APK 可以从这里下载。这两个 APK 都是从 Google Play 下载的,一个是“原始的”,一个是“派生的”,所以除了签名之外它们应该是相同的。有趣的是,它们的尺寸略有不同。11,590,297 字节与 11,601,619 字节。

查看adb shell dumpsys package domain-preferred-apps原始签名 apk 的输出是

  Package: com.scribble.exquisitecorpse
  Domains: letsdraw.fun scribble-cloud.appspot.com scribble-cloud-v24-test-dot-scribble-cloud.appspot.com
  Status:  always : 200000000

而 Google Play 签名的 apk 是

  Package: com.scribble.exquisitecorpse
  Domains: letsdraw.fun scribble-cloud.appspot.com scribble-cloud-v24-test-dot-scribble-cloud.appspot.com
  Status:  ask

使用@ymindstorm 提到的测试页面进行测试时

https://developers.google.com/digital-asset-links/tools/generator

我收到消息

成功!主持人letsdraw.fun 授予应用程序深度链接到com.scribble.exquisitecorpse。

您对可能导致这种情况的原因有什么建议吗?

更新: 我现在已将此作为错误报告给 Google,因为我无法弄清楚发生了什么。 https://issuetracker.google.com/issues/162564916

4

2 回答 2

2

我最终得到了谷歌的帮助......这不是一个错误。

构建过程正在从文件中合并到主机中network_security_config.xml,因此即使AndroidManifest.xml指定了文件:

        <intent-filter android:autoVerify="true">
            <action android:name="android.intent.action.VIEW" />

            <category android:name="android.intent.category.DEFAULT" />
            <category android:name="android.intent.category.BROWSABLE" />

            <data android:host="letsdraw.fun" android:pathPrefix="/ec" android:scheme="https" />
            <data android:host="letsdraw.fun" android:pathPrefix="/restore" android:scheme="https" />
        </intent-filter>

构建过程中的文件也指定了其他主机:

        <intent-filter
            android:autoVerify="true">

            <action
                android:name="android.intent.action.VIEW" />

            <category
                android:name="android.intent.category.DEFAULT" />

            <category
                android:name="android.intent.category.BROWSABLE" />

            <data
                android:scheme="http"
                android:host="scribble-cloud-v24-test-dot-scribble-cloud.appspot.com"
                android:pathPrefix="/ec" />

            <data
                android:scheme="https"
                android:host="scribble-cloud.appspot.com"
                android:pathPrefix="/ec" />

            <data
                android:scheme="https"
                android:host="letsdraw.fun"
                android:pathPrefix="/ec" />

            <data
                android:scheme="https"
                android:host="letsdraw.fun"
                android:pathPrefix="/restore" />
        </intent-filter>

页面上,它指出

只有当系统为清单中的所有主机找到匹配的数字资产链接文件时,它才会将您的应用程序建立为指定 URL 模式的默认处理程序。

问题是我的测试主机没有返回与assetlinks.json其他主机相同的文件。

构建您的 APK 后,使用 IntelliJ 或 Android Studio 转到Build | Analyze Apk并打开刚刚构建的 APK 以检查您的主机是否正确并且assetlinks.json文件返回正确的签名。

为什么要像这样合并清单文件?希望我们能在这里找到答案!

于 2020-12-08T17:22:17.320 回答
0

文档指出:

要为您的应用启用链接处理验证,请android:autoVerify="true"在您的应用清单中设置任何一个 Web URL 意图过滤器,其中包括android.intent.action.VIEW意图操作和android.intent.category.BROWSABLE意图类别 [...]

android:autoVerify="true"出现在您的任何一个意图过滤器上时,在运行 Android 6.0 及更高版本的设备上安装您的应用程序会导致系统尝试验证与您应用程序的任何意图过滤器中的 URL 关联的所有主机。验证涉及以下内容:

系统检查所有意图过滤器,包括:

  • 行动:android.intent.action.VIEW
  • 类别:android.intent.category.BROWSABLEandroid.intent.category.DEFAULT
  • 数据方案:http 或 https 对于在上述意图过滤器中找到的每个唯一主机名,Android 会在相应网站中查询位于 的 Digital Asset Links 文件https://<hostname>/.well-known/assetlinks.json

只有当系统为清单中的所有主机找到匹配的数字资产链接文件时,它才会将您的应用程序建立为指定 URL 模式的默认处理程序。

因此,为了让您跳过消歧对话框,您需要验证您是否正确配置了您的应用程序并且assetlinks.json 在正确的位置可用。根据经验,常见的陷阱是:

  • 忘记autoVerify
  • 在一个语句中声明了多个链接,并且每个域上都没有正确的关联文件
  • 忘记之前授予开发应用程序特殊权限
  • 安装了多个应用程序,它试图将自己注册为链接的解析器

您可以使用这个方便的工具来检查您的配置文件是否正确:

https://developers.google.com/digital-asset-links/tools/generator

于 2020-07-31T12:15:22.730 回答