【问题标题】:Opening PDF in 3rd party app causes TransactionTooLargeException在 3rd 方应用程序中打开 PDF 会导致 TransactionTooLargeException
【发布时间】:2019-10-21 21:13:00
【问题描述】:

我有以下代码 sn-p 应该在外部应用程序中打开 PDF:

Uri uri = FileProvider.getUriForFile(context, BuildConfig.APPLICATION_ID + ".provider", new File(path));
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);
intent.setDataAndType(uri, "application/pdf");
context.startActivity(intent);

这会在 Adob​​e Reader 中打开 PDF,但我的应用程序也会因 TransactionTooLargeException 异常而崩溃。

看起来我只是通过意图发送文件 URI 和类型,因此来自 StackOvrflow 的其他答案的 1MB 限制并不真正适用。

堆栈跟踪:

java.lang.RuntimeException: android.os.TransactionTooLargeException: data parcel size 20439376 bytes
at android.app.ActivityThread$StopInfo.run(ActivityThread.java:4211)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6688)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1468)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1358)
Caused by: android.os.TransactionTooLargeException: data parcel size 20439376 bytes
at android.os.BinderProxy.transactNative(Native Method)
at android.os.BinderProxy.transact(Binder.java:628)
at android.app.ActivityManagerProxy.activityStopped(ActivityManagerNative.java:4132)
at android.app.ActivityThread$StopInfo.run(ActivityThread.java:4203)
at android.os.Handler.handleCallback(Handler.java:751) 
at android.os.Handler.dispatchMessage(Handler.java:95) 
at android.os.Looper.loop(Looper.java:154) 
at android.app.ActivityThread.main(ActivityThread.java:6688) 
at java.lang.reflect.Method.invoke(Native Method) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1468) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1358) 

我错过了什么?

谢谢!

【问题讨论】:

  • 请编辑问题并发布与此异常相关的整个 Java 堆栈跟踪。也许它发生在其他地方(例如,与您保存的实例状态Bundle 相关联)只是由于在此处调用startActivity() 而发生的。

标签: android


【解决方案1】:

我遇到了这个错误,并且 PDF 数据的事情是一个红鲱鱼(支持在应用程序从崩溃中启动时 PDF 成功打开的事实。)

在我的情况下,发生错误是因为我试图在活动 onSaveInstanceState 包中存储太多数据。我在操作中得到了一个非常相同的堆栈跟踪。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多