【发布时间】:2016-04-08 08:26:22
【问题描述】:
我有一个FileProvider,用于将 SD 卡上的文件附加到电子邮件中。
这适用于任何使用Intent 的应用中的Lollipop 和Marshmallow。
但是,在Android 4.3 中,当使用Email 应用程序时,附件会在撰写时出现在电子邮件中,但在发送时,在收件人端,附件不存在。它适用于所有其他经过测试的应用程序(Gmail、Evernote、Drive)。
我不会在发送电子邮件之前删除文件。
这是我的代码。
final Intent fileShareIntent = new Intent(android.content.Intent.ACTION_SEND);
fileShareIntent.putExtra(android.content.Intent.EXTRA_SUBJECT, emailSubject);
fileShareIntent.putExtra(android.content.Intent.EXTRA_TEXT, emailText);
Uri fileUri = STFileProvider.getContentUriForProvidedFile(this,file);
fileShareIntent.putExtra(Intent.EXTRA_STREAM,fileUri);
fileShareIntent.setType(mimeType);
fileShareIntent.putExtra(android.content.Intent.EXTRA_EMAIL, new String[]{prefs.getString("default_email_preference", "")});
startActivity(Intent.createChooser(fileShareIntent,getString(R.string.share_with)));
编辑我发现了一个异常的堆栈跟踪,它符合@CommonsWare 的建议
01-04 17:39:00.430 6828-6828/? W/System.err: java.lang.IllegalArgumentException: column '_data' does not exist
01-04 17:39:00.430 6828-6828/? W/System.err: at android.database.AbstractCursor.getColumnIndexOrThrow(AbstractCursor.java:303)
01-04 17:39:00.430 6828-6828/? W/System.err: at android.database.CursorWrapper.getColumnIndexOrThrow(CursorWrapper.java:78)
01-04 17:39:00.430 6828-6828/? W/System.err: at com.android.email.activity.MessageCompose.getFilePath(MessageCompose.java:21476)
01-04 17:39:00.430 6828-6828/? W/System.err: at com.android.email.activity.MessageCompose.getFilePathOfAttachment(MessageCompose.java:17710)
01-04 17:39:00.430 6828-6828/? W/System.err: at com.android.email.activity.MessageCompose.addAttachment(MessageCompose.java:19140)
01-04 17:39:00.430 6828-6828/? W/System.err: at com.android.email.activity.MessageCompose.access$11000(MessageCompose.java:362)
01-04 17:39:00.430 6828-6828/? W/System.err: at com.android.email.activity.MessageCompose$LoadAttachmentsTaskFromIntent.onProgressUpdate(MessageCompose.java:15277)
01-04 17:39:00.430 6828-6828/? W/System.err: at com.android.email.activity.MessageCompose$LoadAttachmentsTaskFromIntent.onProgressUpdate(MessageCompose.java:15101)
01-04 17:39:00.430 6828-6828/? W/System.err: at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:647)
01-04 17:39:00.430 6828-6828/? W/System.err: at android.os.Handler.dispatchMessage(Handler.java:99)
01-04 17:39:00.430 6828-6828/? W/System.err: at android.os.Looper.loop(Looper.java:176)
01-04 17:39:00.430 6828-6828/? W/System.err: at android.app.ActivityThread.main(ActivityThread.java:5419)
01-04 17:39:00.430 6828-6828/? W/System.err: at java.lang.reflect.Method.invokeNative(Native Method)
01-04 17:39:00.430 6828-6828/? W/System.err: at java.lang.reflect.Method.invoke(Method.java:525)
01-04 17:39:00.430 6828-6828/? W/System.err: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1046)
01-04 17:39:00.430 6828-6828/? W/System.err: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:862)
01-04 17:39:00.430 6828-6828/? W/System.err: at dalvik.system.NativeStart.main(Native Method)
【问题讨论】:
-
你可以试试this fix。我在my CWAC-Provider library 中有该解决方案的打包版本。
-
我不认为这是同一个问题。它根本没有崩溃,只是发送时附件没有保持连接状态。
-
我没有使用过电子邮件应用程序。如果它在其 UI 中显示一些只能从实际流中获取的细节,那么你是对的,这不是问题。 OTOH,如果您在 UI 中看到的唯一内容是可以在不实际使用
Uri内容的情况下确定的内容,那么它们可能只是捕获了与DATA相关的实现损坏的异常。由于您已经有一个自定义FileProvider子类,添加我的LegacyCompatCursorWrapper应该只需要大约 6 行左右(依赖 +query()),所以它可能值得一试。 -
目前我没有对 CRUD 操作做任何事情。事实上,在学习完教程之后,他们所做的只是抛出新的 RuntimeExceptions。我不确定如何将
LegacyCompatCursorWrapper与我的FileProvider子类一起使用,因为我没有Cursor开头 -
@CommonsWare 请参阅堆栈跟踪更新的原始问题