Open PDFs without downloading using JavaScript

Due to the nature of the web, opening a PDF document in the browser involves sending its data over to the user’s browser, which makes it impossible to fully prevent the user from downloading it.

However, there are a few ways Nutrient Web SDK can make this more difficult, so as to discourage users who wish to do this.

Try for free Launch demo

Disabling exporting

You can prevent a user from using the export toolbar item to download your PDF by omitting it from the list of toolbar items provided in the configuration:

instance.setToolbarItems(items => items.filter((item) => item.type !== "export-pdf");

To read more about the download/export button, see our download/export button guide.

Watermarking

You can use text annotations to render text in a PDF with a user’s details — such as their username — to discourage sharing of your document with other customers:

// Create a free text annotation.
const textAnnotation = new PSPDFKit.Annotations.TextAnnotation({
  boundingBox: new PSPDFKit.Geometry.Rect({
    left: 228,
    top: 924,
    width: 600,
    height: 80
  }),
  fontSize: 40,
  text: {
    format: "plain",
    value: `Generated For ${username}`,
  },
  pageIndex: 0
});

// Add the annotations to the document.
await instance.create(textAnnotation);

Using a password

To prevent unauthorized exporting of your documents, Nutrient Web SDK supports the protection of documents with a password. When saving your PDF from your PDF authoring tool, set a password for it.

Server-side rendering

Nutrient Web SDK server-backed instances will use the server to stream the pages it’s looking at as images instead of streaming the complete PDF document to the user’s browser.

Learn more about the Nutrient Web SDK server-backed operational mode.