2011-08-04 18 views

答えて

2

おかげでネイティブXMP構造は、著作権が実装されていない(あるいは、少なくとも彼らは、Adobe Readerが認識するような方法でない。)は、Adobeが出キック何エンジニアを逆にすることができますことを行うためにと手動で書きます:

 String inputPDF = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Desktop), "Services.pdf"); 
     String outputPDF = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Desktop), "Services_Out.pdf"); 

     PdfReader reader = new PdfReader(inputPDF); 
     using (FileStream fs = new FileStream(outputPDF, FileMode.Create, FileAccess.Write, FileShare.Read)) 
     { 
      using (PdfStamper stamper = new PdfStamper(reader, fs)) 
      { 
       using (MemoryStream ms = new MemoryStream()) 
       { 

        string CopyrightName = "YOUR NAME HERE"; 
        string CopyrightUrl = "http://www.example.com/"; 

        XmpWriter xmp = new XmpWriter(ms); 
        xmp.AddRdfDescription("xmlns:dc=\"http://purl.org/dc/elements/1.1/\"", String.Format("<dc:rights><rdf:Alt><rdf:li xml:lang=\"x-default\">{0}</rdf:li></rdf:Alt></dc:rights>", CopyrightName)); 
        xmp.AddRdfDescription("xmlns:xmpRights=\"http://ns.adobe.com/xap/1.0/rights/\"", string.Format("<xmpRights:Marked>True</xmpRights:Marked><xmpRights:WebStatement>{0}</xmpRights:WebStatement>", CopyrightUrl)); 
        xmp.Close(); 
        stamper.XmpMetadata = ms.ToArray(); 
        stamper.Close(); 

       } 
      } 
     } 
関連する問題