react-native-pdf-view - 如何使用 base64 或 blob 填充 pdfView

react-native-pdf-view - How to populate pdfView with base64 or blob

我正在使用 react-native-pdf-view 库,但在使用 pdf 填充 PDFView 时遇到问题。

我的项目是如何工作的,我从服务器接收一个 base64 pdf,然后我使用库 react-native-fs 保存到 android 文件系统,如下所示:
(这很好用)

saveFile(filename){

   var base64Image = this.state.imageBase64;

   // create a path you want to write to
   var path = RNFS.DocumentDirectoryPath + '/' + filename;

   // write the file
   RNFS.writeFile(path, base64Image, 'base64').then((success) => {
     console.log('FILE WRITTEN!');
     this.setState(
       {pdf_dirPath: path}
     );
     this._display_fileAttachment()
   })
   .catch((err) => {
     console.log(err.message);
   });
 }

然后我尝试用这个填充 pdf 视图:

<PDFView
  ref={(pdf)=>{this.pdfView = pdf;}}
  src={"path/To/base64/pdf"}
  style={styles.pdf}
 />

问题

react-native-pdf-view 是否必须采用文件位置,还是可以采用 base64 pdf 或 blob。

如果它可以使用 base64 或 blob,请解释或提供示例代码如何操作。
谢谢

Nb: 非常相似,但我需要知道如何以何种形式从文件系统中保存或检索 base64,以及如何填充 pdf。

对于遇到相同问题的任何人,这里是解决方案。 解决方案

react-native-pdf-view 一定要把文件路径取到pdf_base64.

首先,我使用 react-native-fetch-blob 从服务器请求 pdf base64。 (因为 RN fetch API 还不支持 BLOB)。

此外,我发现 react-native-fetch-blob 也有一个文件系统 API,它比 'react-native-fs' 库有更好的记录和更容易理解。 (Check out its FileSystem API documentation)

接收base64 pdf并保存到文件路径:

var RNFetchBlob = require('react-native-fetch-blob').default;

const DocumentDir = RNFetchBlob.fs.dirs.DocumentDir;

getPdfFromServer: function(uri_attachment, filename_attachment) {
   return new Promise((RESOLVE, REJECT) => {

      // Fetch attachment
      RNFetchBlob.fetch('GET', config.apiRoot+'/app/'+uri_attachment)
      .then((res) => {
       
          let base64Str = res.data;
          let pdfLocation = DocumentDir + '/' + filename_attachment;

          RNFetchBlob.fs.writeFile(pdfLocation, pdf_base64Str, 'base64');
          RESOLVE(pdfLocation);
      })
   }).catch((error) => {
       // error handling
       console.log("Error", error)
   });
}

我做错的是没有像上面的示例那样将 pdf_base64Str 保存到文件位置。我是这样保存的:

var pdf_base64= 'data:application/pdf;base64,'+pdf_base64Str;

这是错误的。

使用文件路径填充 PDF 视图:

<PDFView
    ref={(pdf)=>{this.pdfView = pdf;}}
    src={pdfLocation}
    style={styles.pdf}
/>
        

似乎有更简单的方法可以做到这一点。只需告诉 RNFletchBlob 像这样直接保存到磁盘即可。请注意,您稍后必须清理该文件。

RNFetchBlob
  .config({
    // add this option that makes response data to be stored as a file. 
    fileCache : true,
    appendExt : 'pdf'
  })
  .fetch('GET', 'http://www.example.com/file/example.zip', {
    //some headers ..
  })
  .then((res) => {
    // the temp file path 
    this.setState({fileLocation: res.path()});
    console.log('The file saved to ', res.path())
  })

稍后

<PDFView 
  ref={(pdf)=>{this.pdfView = pdf;}}
  path={this.state.fileLocation}
  onLoadComplete = {(pageCount)=>{
    this.pdfView.setNativeProps({
      zoom: 1.0
    });
    console.log("Load Complete. File has " + pageCount + " pages.");
  }}
  style={styles.pdf}/>