Open a PDF on Server/Desktop

To open a PDF document.

1// open document from the filesystem
2PDFDoc doc = new PDFDoc(filename);
3
4// optionally read a PDF document from a stream
5MappedFile file = new MappedFile(filename);
6PDFDoc doc_stream = new PDFDoc(file);
7
8// or pass-in a memory buffer
9long file_sz = file.FileSize();
10FilterReader file_reader = new FilterReader(file);
11byte[] mem = new byte[(int) file_sz];
12long bytes_read = file_reader.Read(mem);
13PDFDoc doc_mem = new PDFDoc(mem, file_sz);
14
15// load from a URL
16Uri url = new Uri("https://myserver.com/myfile.pdf");
17HttpClient client = new HttpClient();
18var file_content = client.GetByteArrayAsync(url);
19PDFDoc doc = new PDFDoc(new MemoryStream(file_content));

Read & write a PDF file from/to memory buffer
Full source code which illustrates how to read/write a PDF document from/to memory buffer. This is useful for applications that work with dynamic PDF documents that don't need to be saved/read from a disk.

About opening a document

The PDFDoc constructor creates a PDF document from scratch:

PDFDoc.Close()

When you are finished with a PDFDoc object, the PDFDoc.Close() method should be called to clean up memory, file handles, and resources.

1PDFDoc new_doc = new PDFDoc();

A newly-created document does not yet contain any pages. See the accessing pages section for details on creating new pages and working with existing pages.

Using Apryse SDK, you can open a document from a serialized file, from a memory buffer, or from a Filter stream.

To open an existing PDF document from a file, specify its file path in the PDFDoc constructor:

1PDFDoc new_doc = new PDFDoc(filename);

Here's how to open an existing PDF document from a memory buffer:

1MappedFile file = new MappedFile(filename);
2long file_sz = file.FileSize();
3FilterReader file_reader = new FilterReader(file);
4byte[] mem = new byte[(int) file_sz];
5long bytes_read = file_reader.Read(mem);
6PDFDoc doc_mem = new PDFDoc(mem, file_sz);

It's also easy to open a PDF document from a MemoryFilter or a custom Filter .

After creating a PDFDoc object, it's good practice to call InitSecurityHandler() on it. If the document is encrypted, calling the method will decrypt it. If the document is not encrypted, calling the method is harmless.

1PDFDoc doc = new PDFDoc(filename);
2if (!doc.InitSecurityHandler())
3{
4 Console.WriteLine("Document authentication error...");
5 return;
6}

Did you find this helpful?

Trial setup questions?

Ask experts on Discord

Need other help?

Contact Support

Pricing or product questions?

Contact Sales