How can I help you?
Open PDF from Dropbox cloud storage
28 Feb 202610 minutes to read
The Vue PDF Viewer component supports loading PDF files from Dropbox using either the standalone or the server-backed PDF Viewer. The following sections walk through both approaches.
Using the standalone PDF Viewer
To load a PDF file from Dropbox cloud storage in the standalone PDF Viewer, follow these steps:
Step 1: Create a Dropbox API app
Follow the Dropbox documentation to create an API app: https://www.dropbox.com/developers/documentation/dotnet#tutorial. This enables programmatic access with secure credentials.
Step 2: Create a PDF Viewer sample in Vue
Start by following the PDF Viewer getting started guide for Vue to create a simple PDF Viewer sample. This provides the basic setup for the PDF Viewer component.
Step 3: Modify the src/App.vue file in the Vue project
- Import the required module at the top of the file:
<script>
import { Dropbox } from 'dropbox';
</script>- Create an instance of the Dropbox class using an access token for authentication. Call the
filesDownloadmethod to download the desired file (for example,/PDF_Succinctly.pdf). Extract the file blob from the response, convert it to a Base64 string using theblobToBase64helper, and load the Base64 string into the PDF Viewer control.
NOTE
Replace the placeholder with the actual Dropbox access token. For production, store secrets securely (for example, environment variables, user secrets, or a secret store such as Azure Key Vault) and do not commit credentials to source control.
<script>
export default {
methods: {
async loadPdfDocument() {
const dbx = new Dropbox({ accessToken: 'Your Access Token' });
dbx.filesDownload({ path: '/PDF_Succinctly.pdf' }).then(async (response) => {
const blob = await response.result.fileBlob;
const base64String = await this.blobToBase64(blob);
const viewer = document.getElementById('pdfViewer').ej2_instances[0];
setTimeout(() => {
viewer.load(base64String, "");
}, 2000);
});
},
blobToBase64(blob) {
return new Promise((resolve, reject) => {
const reader = new FileReader();
reader.onloadend = () => resolve(reader.result);
reader.onerror = reject;
reader.readAsDataURL(blob);
});
},
},
};
</script>NOTE
The npm install dropbox package must be installed in the Vue application to use the Dropbox SDK.
Using the server-backed PDF Viewer
To load a PDF file from Dropbox cloud storage in the server-backed PDF Viewer, follow these steps:
Step 1: Create a Dropbox API app
Follow the Dropbox documentation to create an API app: https://www.dropbox.com/developers/documentation/dotnet#tutorial. This enables programmatic access with secure credentials.
Step 2: Create a PDF Viewer sample in Vue
Follow the steps in this getting started guide to set up a basic Vue PDF Viewer application.
Step 3: Modify the PdfViewerController.cs file in the web service project
-
Create a web service project in .NET Core 3.0 or above. Refer to this article for guidance on creating the web service project.
-
Open the
PdfViewerController.csfile in the web service project. -
Import the required namespaces at the top of the file:
using System.IO;
using Dropbox.Api;
using Dropbox.Api.Files;- Add the following private fields and constructor parameters to the
PdfViewerControllerclass. In the constructor, assign the values from the configuration to the corresponding fields.
private IConfiguration _configuration;
public readonly string _accessToken;
public readonly string _folderName;
public PdfViewerController(IWebHostEnvironment hostingEnvironment, IMemoryCache cache, IConfiguration configuration)
{
_hostingEnvironment = hostingEnvironment;
_cache = cache;
_configuration = configuration;
_accessToken = _configuration.GetValue<string>("AccessToken");
_folderName = _configuration.GetValue<string>("FolderName");
}- Modify the
Load()method to load the PDF files from Dropbox cloud storage.
[HttpPost("Load")]
[Microsoft.AspNetCore.Cors.EnableCors("MyPolicy")]
[Route("[controller]/Load")]
// Post action for loading the PDF documents
public async Task<IActionResult> Load([FromBody] Dictionary<string, string> jsonObject)
{
// Initialize the PDF viewer object with memory cache object
PdfRenderer pdfviewer = new PdfRenderer(_cache);
MemoryStream stream = new MemoryStream();
object jsonResult = new object();
if (jsonObject != null && jsonObject.ContainsKey("document"))
{
if (bool.Parse(jsonObject["isFileName"]))
{
// Get the file name from the jsonObject, which should contain the Dropbox file name
string fileName = jsonObject["document"];
using (var dropBox = new DropboxClient(_accessToken))
{
using (var response = await dropBox.Files.DownloadAsync(_folderName + "/" + fileName))
{
var byteArray = await response.GetContentAsByteArrayAsync();
// Load the PDF file into the PDF viewer
stream = new MemoryStream(byteArray);
}
}
}
else
{
byte[] bytes = Convert.FromBase64String(jsonObject["document"]);
stream = new MemoryStream(bytes);
}
}
jsonResult = pdfviewer.Load(stream, jsonObject);
return Content(JsonConvert.SerializeObject(jsonResult));
}- Open the
appsettings.jsonfile in the web service project and add the following lines below the existing"AllowedHosts"configuration:
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
},
"AllowedHosts": "*",
"AccessToken": "Your_Dropbox_Access_Token",
"FolderName": "Your_Folder_Name"
}NOTE
Replace the placeholders with the actual Dropbox access token and folder name.
Step 4: Configure the PDF Viewer component
Set the serviceUrl property of the PDF Viewer component to the URL of the web service project (replace https://localhost:44396/pdfviewer with the actual server URL). Set the documentPath property to the name of the PDF file that needs to be loaded from Dropbox. Ensure the document name matches a file in the Dropbox folder.
<template>
<div id="app">
<ejs-pdfviewer id="pdfViewer" :serviceUrl="serviceUrl" :documentPath="documentPath">
</ejs-pdfviewer>
</div>
</template>
<script setup>
import { provide } from "vue";
import {
PdfViewerComponent as EjsPdfviewer, Toolbar, Magnification, Navigation, LinkAnnotation, BookmarkView,
ThumbnailView, Print, TextSelection, TextSearch, Annotation, FormFields, FormDesigner
} from '@syncfusion/ej2-vue-pdfviewer';
// Replace the "localhost:44396" with the actual URL of the server
const serviceUrl = "https://localhost:44396/pdfviewer";
const documentPath = "PDF_Succinctly.pdf";
provide('PdfViewer', [Toolbar, Magnification, Navigation, LinkAnnotation, BookmarkView, ThumbnailView,
Print, TextSelection, TextSearch, Annotation, FormFields, FormDesigner]);
</script><template>
<div id="app">
<ejs-pdfviewer id="pdfViewer" :serviceUrl="serviceUrl" :documentPath="documentPath">
</ejs-pdfviewer>
</div>
</template>
<script>
import {
PdfViewerComponent, Toolbar, Magnification, Navigation, LinkAnnotation, BookmarkView,
ThumbnailView, Print, TextSelection, TextSearch, Annotation, FormFields, FormDesigner
} from '@syncfusion/ej2-vue-pdfviewer';
export default {
name: 'app',
components: {
'ejs-pdfviewer': PdfViewerComponent
},
data() {
return {
// Replace the "localhost:44396" with the actual URL of the server
serviceUrl: "https://localhost:44396/pdfviewer",
documentPath: "PDF_Succinctly.pdf"
};
},
provide: {
PdfViewer: [Toolbar, Magnification, Navigation, LinkAnnotation, BookmarkView, ThumbnailView,
Print, TextSelection, TextSearch, Annotation, FormFields, FormDesigner]
}
};
</script>NOTE
The Dropbox.Api NuGet package must be installed in the web service project to use the Dropbox SDK.
NOTE
Replace
PDF_Succinctly.pdfwith the actual document name to load from Dropbox. Ensure the specified document exists in the configured Dropbox folder and is passed to thedocumentPathproperty of the PDF Viewer component.