Android 为什么'Intent.createChooser(shareIntentWithJpgFileName)`停止工作? 图像文件不再通过选择器

Android 为什么'Intent.createChooser(shareIntentWithJpgFileName)`停止工作? 图像文件不再通过选择器,android,android-security,android-intent-chooser,Android,Android Security,Android Intent Chooser,代码startActivity(intent.createChooser(shareIntentWithJpgFileName))多年来一直在我的应用程序中运行良好,但大约一个月前我注意到它不再将图像文件传递给用户在选择器对话框中选择的应用程序。我怀疑Android操作系统的安全性(再次!),但不知道如何继续 如果用户在选择器对话框中选择任意数量的选项,应用程序将打开,但不会显示作为意图一部分的.jpg。如果用户选择Google Drive,我会从它的toast中得到一个错误提示: 上载失败:请

代码
startActivity(intent.createChooser(shareIntentWithJpgFileName))
多年来一直在我的应用程序中运行良好,但大约一个月前我注意到它不再将图像文件传递给用户在选择器对话框中选择的应用程序。我怀疑Android操作系统的安全性(再次!),但不知道如何继续

如果用户在选择器对话框中选择任意数量的选项,应用程序将打开,但不会显示作为意图一部分的
.jpg
。如果用户选择Google Drive,我会从它的toast中得到一个错误提示:

上载失败:请求不包含任何数据

用于工作的代码: 另外,我将其作为
AndroidManifest.xml
的一部分:

<provider    
    android:name="android.support.v4.content.FileProvider"    
    android:authorities="${applicationId}.provider"    
    android:exported="false"    
    android:grantUriPermissions="true">    
    <meta-data    
        android:name="android.support.FILE_PROVIDER_PATHS"    
        android:resource="@xml/provider_paths"/>    
</provider>    
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
问题: 为什么它停止工作了?我怎样才能让它重新工作

我很乐意维护/更新/修复/更正/删除此问题,因此,如果您因任何原因感到不满意,请给我指导

补遗 我将
Logcat
中的过滤器从“仅显示选定的应用程序”更改为“无过滤器”,并且能够查看所有应用程序的日志记录。大概有50行左右的文字出现了。很难判断哪些项目适用于我启动的意图,但有些项目显然来自我启动的意图(在选择器对话框中选择了Google Drive)。我选择了几个更有趣的日志条目:

I/ActivityManager: START u0 {act=android.intent.action.SEND typ=image/jpeg flg=0xb080001 cmp=com.google.android.apps.docs/.shareitem.UploadMenuActivity (has extras)} from uid 10196
E/SchedPolicy: open of /dev/cpuctl/bg_non_interactive/tasks failed: No such file or directory
I/ActivityManager: Start proc 12705:com.google.android.apps.docs/u0a92 for activity com.google.android.apps.docs/.shareitem.UploadMenuActivity
E/AsyncTask #3-DataSourceHelper: Uploading single file but neither EXTRA_STREAM nor EXTRA_TEXT is specified.
E/main-UploadMenuActivity: No files requested to be uploaded: android.intent.action.SEND
I/LaunchCheckinHandler: Displayed com.google.android.apps.docs/.shareitem.UploadMenuActivity,cp,ca,570

我的下一步是检查“EXTRA_STREAM”,虽然我还没有完成,但我可能很快就能自己解决这个问题。

ACTION_SEND
使用
Intent。EXTRA_STREAM
用于二进制内容,不是
MediaStore.EXTRA_OUTPUT

我想您已经对
filePassedIn
进行了一些健全性检查,例如
File::exists
File::canRead
等,只是为了预先排除这个问题?谢谢马克。我在代码中添加了一行调试代码。两者都返回true。我猜
MediaStore.EXTRA_输出
将退出获得支持<代码>意图。额外的\u流就像一个符咒。
I/ActivityManager: START u0 {act=android.intent.action.SEND typ=image/jpeg flg=0xb080001 cmp=com.google.android.apps.docs/.shareitem.UploadMenuActivity (has extras)} from uid 10196
E/SchedPolicy: open of /dev/cpuctl/bg_non_interactive/tasks failed: No such file or directory
I/ActivityManager: Start proc 12705:com.google.android.apps.docs/u0a92 for activity com.google.android.apps.docs/.shareitem.UploadMenuActivity
E/AsyncTask #3-DataSourceHelper: Uploading single file but neither EXTRA_STREAM nor EXTRA_TEXT is specified.
E/main-UploadMenuActivity: No files requested to be uploaded: android.intent.action.SEND
I/LaunchCheckinHandler: Displayed com.google.android.apps.docs/.shareitem.UploadMenuActivity,cp,ca,570