我的应用程序列出了PDF文件,当用户选择PDF时,该应用程序将其打开。如果用户选择了损坏的PDF文件,PdfRenderer会抛出IOException
(这很好,因为我捕获到该异常并通知用户该文件已损坏)。
但是问题是,在这种情况发生之后,用户尝试打开的所有PDF文件(甚至是未损坏的PDF文件)都会抛出 IOException
相关代码
File file = new File(filePath);
mFileDescriptor = ParcelFileDescriptor.open(file, ParcelFileDescriptor.MODE_READ_ONLY);
if (mFileDescriptor != null) {
mPdfRenderer = new PdfRenderer(mFileDescriptor);
}
Stacktrace
openRenderer: java.io.IOException: file not in PDF format or corrupted
at android.graphics.pdf.PdfRenderer.nativeCreate(Native Method)
at android.graphics.pdf.PdfRenderer.<init>(PdfRenderer.java:166)
at ****.****.****.PdfUtil.openRenderer(PdfUtil.java:63)
at ****.****.****.PdfUtil.getMaxPages(PdfUtil.java:46)
at ****.****.****.PdfViewActivity.init(PdfViewActivity.java:166)
at ****.****.****.ui.PdfViewActivity.onCreate(PdfViewActivity.java:58)
at android.app.Activity.performCreate(Activity.java:7023)
at android.app.Activity.performCreate(Activity.java:7014)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1215)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2745)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2870)
at android.app.ActivityThread.-wrap11(Unknown Source:0)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1601)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:172)
at android.app.ActivityThread.main(ActivityThread.java:6590)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
为什么会这样?我该如何解决?
注意:我已经尝试将pdf文件复制到缓存目录。没关系。
PdfRenderer Google示例存储库here.
中存在相同问题