1

编辑:

system_process当我单击固定的快捷方式时,我正在登录以下:

2019-10-26 20:00:16.086 2047-3533/system_process I/ActivityTaskManager: START u0 {act=android.intent.action.VIEW dat=file:///storage/emulated/0/Download/AAD.pdf typ=application/pdf flg=0x10000000 cmp=com.google.android.apps.docs/com.google.android.apps.viewer.PdfViewerActivity bnds=[439,84][641,337]} from uid 10147
2019-10-26 20:00:16.100 2047-2047/system_process W/ActivityManager: Unable to start service Intent { act=android.service.appprediction.AppPredictionService cmp=com.google.android.as/com.google.android.apps.miphone.aiai.app.AiAiPredictionService } U=0: not found
2019-10-26 20:00:16.100 2047-2047/system_process W/RemoteAppPredictionService: could not bind to Intent { act=android.service.appprediction.AppPredictionService cmp=com.google.android.as/com.google.android.apps.miphone.aiai.app.AiAiPredictionService } using flags 67108865

简而言之,固定快捷方式不会在 Android 10 中打开,但可以在旧版本中使用。在 Android 10 中,当我单击快捷方式时,Drive PDF Viewer 会打开,但实际文件显示为黑色空间,并在一秒钟内关闭应用程序。

老的:

我的 Android 应用程序以 API 级别 28 为目标。它将 PDF 文件的快捷方式固定到主屏幕,然后单击图标会明显打开文件。直到 Android Pie,它工作得非常好。但是当我在 API 29 上对其进行测试时,单击该图标会打开 PDF 查看器并强制关闭且没有错误。这是相关的代码。

private fun addShortcutInOreo(path1: String, pdfName: String) {
        val file = File(path1)
        try {
            Log.d("Data", file.path)
            val pdfIntent = Intent(Intent.ACTION_VIEW)

            val uri = Uri.fromFile(file)

            pdfIntent.setDataAndType(uri, "application/pdf")
            pdfIntent.flags = Intent.FLAG_GRANT_READ_URI_PERMISSION
            pdfIntent.flags = Intent.FLAG_GRANT_WRITE_URI_PERMISSION

            Log.d("DataPath", uri.path)
            Log.d("DataPath", pdfName)

            if (Build.VERSION.SDK_INT > 25) {
                val shortcutManager = getSystemService(ShortcutManager::class.java)

                // Check which icon is to be pinned
                image = if (blueIcon.isChecked)
                    R.drawable.pdf
                else
                    R.drawable.pdf2

                // Create a shortcut
                val shortcut = ShortcutInfo.Builder(this, pdfName)
                        .setShortLabel(pdfName)
                        .setLongLabel(pdfName)
                        .setIcon(Icon.createWithResource(this, image))
                        .setIntent(pdfIntent)
                        .build()

                shortcutManager.requestPinShortcut(shortcut, null)
            }
        } catch (e: Exception) {
            errorMessage(e)
        }

    }

记录的数据在这里。第一行显示文件路径。第二行显示 Uri。第三行简单地给出了提取的文件名。我这样做只是为了检查我的代码是否一切正常。

2019-08-02 13:43:14.160 3306-3306/com.parassidhu.pdfpin D/Data: /storage/emulated/0/Download/Nakal.pdf
2019-08-02 13:43:14.160 3306-3306/com.parassidhu.pdfpin D/DataPath: file:///storage/emulated/0/Download/Nakal.pdf
2019-08-02 13:43:14.160 3306-3306/com.parassidhu.pdfpin D/DataPath: Nakal

API 28 的日志相同:

2019-08-02 13:55:07.853 5341-5341/com.parassidhu.pdfpin D/Data: /storage/emulated/0/Download/Nakal.pdf
2019-08-02 13:55:07.853 5341-5341/com.parassidhu.pdfpin D/DataPath: file:///storage/emulated/0/Download/Nakal.pdf
2019-08-02 13:55:07.853 5341-5341/com.parassidhu.pdfpin D/DataPath: Nakal

由于没有错误,我正在挠头,因为可能出了什么问题。我已经阅读了有关 Android Q 中的 Scoped Storage 的信息,但这不适用于这里,因为我不是针对 Q 的。我已经阅读了有关 Android Q 中其他行为更改的信息,但就我所阅读的而言,没有一个适用。

可能是什么问题?谢谢阅读!

4

2 回答 2

1

Uri.fromFile()自 Android 7.0 以来已被有效禁止,因为它会触发FileUriExposedException.

FileProvider在您的应用程序中使用并FileProvider.getUriForFile()创建Uri在您的Intent.

于 2019-10-26T21:41:17.830 回答
1

感谢@CommonsWare 的提示,我解决了这个问题。我做了两个改变:

  1. 对于 Android 7.0 及更高版本,我使用FileProvider.getUriForFile()而不是Uri.fromFile()@CommonsWare 建议的那样。

  2. 我没有使用setFlags()(在 Kotlin 的语法中,它是intent.flags = <flag>),而是使用addFlags()并传递了Intent.FLAG_GRANT_READ_URI_PERMISSION.

解释:

  1. 由于使用了针对 Android 7.0+的Uri.fromFile()方法,因此第一次更改确实很有必要。FileUriExposedException不在应用程序中,因为单击快捷方式时,启动的活动不属于我的应用程序。这就是为什么我无法抓住它。

  2. 我猜这个变化是罪魁祸首。如果我们不添加给定标志,则 PDF 打开活动(或应用程序)没有读取文件内容(或 uri)的权限。这就是活动打开一秒钟然后关闭的原因,因为它无法读取文件。

关于setFlags()vs addFlags(),由于setFlags()删除了现有标志并添加了指定的标志,因此它不起作用。但addFlags()保留现有标志并添加指定标志。因此addFlags()工作。

于 2019-10-28T06:26:14.330 回答