ddango
ddango

Reputation: 956

Extracting Additional Metadata from a PDF using iTextSharp

I've seen the extraction of basic metadata (ie. author, title) using iTextSharp and it usually looks something like this:

var pdfReader = new PdfReader(pdfData);
var author = pdfReader.Info["author"]

However, in my case I'm after something a bit more exotic, the additional "advanced" metadata that the document may contain.

Pardon the paint highlights, but here is a screenshot from within Adobe Acrobat showing the data in question:

the data in question via adobe acrobat

In this case, it doesn't seem like this data is available through the Info dictionary. Using a different library (PDFKit by TallComponents) this data is exposed, but I'm wondering if there is any way get it using iItext

I'm currently playing with iText 4.1.6 due to licensing restrictions, but I wouldn't be opposed to buying the commercial license for 5.0.6 if that adds required functionality.

Upvotes: 2

Views: 10146

Answers (1)

goTo-devNull
goTo-devNull

Reputation: 9372

not sure if it will get exactly what you need, but to get the XMP metadata try something like this:

PdfReader reader = new PdfReader(YOUR_PDF);
byte[] b = reader.Metadata;
if (b != null) {
  string xml = new UTF8Encoding().GetString(b);
}

notice you get back a XML string.

IIRC the code will work with 4.1.6.

Upvotes: 4

Related Questions