Почему `Intent.createChooser (shareIntentWithJpgFileName)` перестал работать? - PullRequest
0 голосов
/ 03 января 2019

Файл изображения больше не пропускается через Chooser

Код startActivity(intent.createChooser(shareIntentWithJpgFileName)) прекрасно работал в моем приложении в течение многих лет, но около месяца назад я заметил, что он больше не передает файл изображения в приложение, котороепользователь выбирает в диалоге выбора.Я подозреваю, что перетасовка безопасности ОС Android (снова!), Но не знаю, как действовать.

Если пользователь выбирает любое количество вариантов в диалоговом окне выбора, приложение открывается, но не показывает .jpgэто было частью намерения.Если пользователь выбирает Google Диск, я получаю подсказку о том, что не так с помощью его тоста:

Загрузка не выполнена: запрос не содержит данных

Код, который использовался для работы:

String fileName = data.getStringExtra(EXTRA_FILENAME);                    
Log.v(TAG, "Starting Share intent.  fileName: " + fileName); //This shows fileName: /storage/emulated/0/dcim/DalesApp/IMG_20190103_142555_8445288886207383328.jpg              
Intent shareIntentWithJpgFileName = new Intent(Intent.ACTION_SEND);                
shareIntentWithJpgFileName.setType("image/jpeg");                
File filePassedIn = new File(fileName); 
Log.v(TAG, "exists: " + filePassedIn.exists() + " canRead: " + filePassedIn.canRead());   // Result is exists: true canRead: true.  Thanks Mark!           
shareIntentWithJpgFileName.putExtra(MediaStore.EXTRA_OUTPUT, FileProvider.getUriForFile(this, BuildConfig.APPLICATION_ID + ".provider", filePassedIn));                
shareIntentWithJpgFileName.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);                
startActivity(Intent.createChooser(shareIntentWithJpgFileName, "Share Image"));                

Кроме того, у меня есть это как часть 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>    

И это также в AndroidManifest.xml:

<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», что я еще не сделал, но я, возможно, близок к решению этого самостоятельно.

1 Ответ

0 голосов
/ 03 января 2019

ACTION_SEND использует Intent.EXTRA_STREAM для двоичного содержимого согласно документации , а не MediaStore.EXTRA_OUTPUT.

...