![]() |
Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Classic ASP) Extract Metadata XML from PDFSee more PDF Signatures ExamplesDemonstrates how to extract the metadata XML from a PDF.
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> </head> <body> <% ' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Pdf") set pdf = Server.CreateObject("Chilkat.Pdf") success = pdf.LoadFile("qa_data/pdf/blank_with_metadata.pdf") If (success = 0) Then Response.Write "<pre>" & Server.HTMLEncode( pdf.LastErrorText) & "</pre>" Response.End End If ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder") set sbXml = Server.CreateObject("Chilkat.StringBuilder") ' Note: Not all PDF files have metadata. Metadata is optional. success = pdf.GetMetadata(sbXml) If (success = 0) Then Response.Write "<pre>" & Server.HTMLEncode( pdf.LastErrorText) & "</pre>" Response.End End If ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Xml") set xml = Server.CreateObject("Chilkat.Xml") success = xml.LoadSb(sbXml,1) Response.Write "<pre>" & Server.HTMLEncode( xml.GetXml()) & "</pre>" ' Sample PDF metadata XML: ' (Code for parsing follows) ' Use this online tool to generate parsing code from sample XML: ' Generate Parsing Code from XML ' <?xml version="1.0" encoding="utf-8"?> ' <x:xmpmeta xmlns:x="adobe:ns:meta/" x:xmptk="Adobe XMP Core 9.1-c001 79.675d0f7, 2023/06/11-19:21:16 "> ' <rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"> ' <rdf:Description rdf:about="" xmlns:xmp="http://ns.adobe.com/xap/1.0/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:xmpMM="http://ns.adobe.com/xap/1.0/mm/" xmlns:pdf="http://ns.adobe.com/pdf/1.3/" xmlns:xmpRights="http://ns.adobe.com/xap/1.0/rights/"> ' <xmp:ModifyDate>2024-11-27T11:33:12-06:00</xmp:ModifyDate> ' <xmp:CreateDate>2024-11-27T11:28:23-06:00</xmp:CreateDate> ' <xmp:MetadataDate>2024-11-27T11:33:12-06:00</xmp:MetadataDate> ' <xmp:CreatorTool>Adobe Acrobat Pro (32-bit) 24.3.20112</xmp:CreatorTool> ' <dc:format>application/pdf</dc:format> ' <dc:title> ' <rdf:Alt> ' <rdf:li xml:lang="x-default">Blank</rdf:li> ' </rdf:Alt> ' </dc:title> ' <dc:creator> ' <rdf:Bag> ' <rdf:li>Chilkat Software</rdf:li> ' </rdf:Bag> ' </dc:creator> ' <dc:description> ' <rdf:Alt> ' <rdf:li xml:lang="x-default">Blank Document</rdf:li> ' </rdf:Alt> ' </dc:description> ' <dc:subject> ' <rdf:Bag> ' <rdf:li>blank</rdf:li> ' <rdf:li>metadata</rdf:li> ' <rdf:li>document</rdf:li> ' </rdf:Bag> ' </dc:subject> ' <xmpMM:DocumentID>uuid:34535ffa-b632-43f1-b1fd-80cea6fdc351</xmpMM:DocumentID> ' <xmpMM:InstanceID>uuid:69ace620-4c54-407f-8d45-6eebc90f34c2</xmpMM:InstanceID> ' <pdf:Producer>Adobe Acrobat Pro (32-bit) 24.3.20112</pdf:Producer> ' <pdf:Keywords>blank; metadata; document</pdf:Keywords> ' <xmpRights:WebStatement>https://www.chilkatsoft.com/</xmpRights:WebStatement> ' </rdf:Description> ' </rdf:RDF> ' </x:xmpmeta> x_xmpmeta_xmlns_x = xml.GetAttrValue("xmlns:x") x_xmpmeta_x_xmptk = xml.GetAttrValue("x:xmptk") rdf_RDF_xmlns_rdf = xml.ChilkatPath("rdf:RDF|(xmlns:rdf)") rdf_Description_rdf_about = xml.ChilkatPath("rdf:RDF|rdf:Description|(rdf:about)") rdf_Description_xmlns_xmp = xml.ChilkatPath("rdf:RDF|rdf:Description|(xmlns:xmp)") rdf_Description_xmlns_dc = xml.ChilkatPath("rdf:RDF|rdf:Description|(xmlns:dc)") rdf_Description_xmlns_xmpMM = xml.ChilkatPath("rdf:RDF|rdf:Description|(xmlns:xmpMM)") rdf_Description_xmlns_pdf = xml.ChilkatPath("rdf:RDF|rdf:Description|(xmlns:pdf)") rdf_Description_xmlns_xmpRights = xml.ChilkatPath("rdf:RDF|rdf:Description|(xmlns:xmpRights)") xmp_ModifyDate = xml.GetChildContent("rdf:RDF|rdf:Description|xmp:ModifyDate") xmp_CreateDate = xml.GetChildContent("rdf:RDF|rdf:Description|xmp:CreateDate") xmp_MetadataDate = xml.GetChildContent("rdf:RDF|rdf:Description|xmp:MetadataDate") xmp_CreatorTool = xml.GetChildContent("rdf:RDF|rdf:Description|xmp:CreatorTool") dc_format = xml.GetChildContent("rdf:RDF|rdf:Description|dc:format") rdf_li_xml_lang = xml.ChilkatPath("rdf:RDF|rdf:Description|dc:title|rdf:Alt|rdf:li|(xml:lang)") rdf_li = xml.GetChildContent("rdf:RDF|rdf:Description|dc:title|rdf:Alt|rdf:li") rdf_li = xml.GetChildContent("rdf:RDF|rdf:Description|dc:creator|rdf:Bag|rdf:li") rdf_li_xml_lang = xml.ChilkatPath("rdf:RDF|rdf:Description|dc:description|rdf:Alt|rdf:li|(xml:lang)") rdf_li = xml.GetChildContent("rdf:RDF|rdf:Description|dc:description|rdf:Alt|rdf:li") i = 0 count_i = xml.NumChildrenHavingTag("rdf:RDF|rdf:Description|dc:subject|rdf:Bag|rdf:li") Do While i < count_i xml.I = i rdf_li = xml.GetChildContent("rdf:RDF|rdf:Description|dc:subject|rdf:Bag|rdf:li[i]") i = i + 1 Loop xmpMM_DocumentID = xml.GetChildContent("rdf:RDF|rdf:Description|xmpMM:DocumentID") xmpMM_InstanceID = xml.GetChildContent("rdf:RDF|rdf:Description|xmpMM:InstanceID") pdf_Producer = xml.GetChildContent("rdf:RDF|rdf:Description|pdf:Producer") pdf_Keywords = xml.GetChildContent("rdf:RDF|rdf:Description|pdf:Keywords") xmpRights_WebStatement = xml.GetChildContent("rdf:RDF|rdf:Description|xmpRights:WebStatement") %> </body> </html> |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.