Search for encrypted text in Metadata signatures
Leave feedback
GroupDocs.Signature provides ability to search encrypted Metadata signatures with standard or custom encryption. Standard encryption is implemented over class SymmetricEncryption class. Creation of this object expects 3 arguments like encryption algorithm enumeration SymmetricAlgorithmType with one of following values (DES, TripleDES, RC2, Rijndael), string value key and string value salt.
Here are the steps to search for encrypted Metadata signature with standard encryption with GroupDocs.Signature:
Create new instance of Signature class and pass source document path or as a constructor parameter.
Compose object of SymmetricEncryption class with same parameters as secured QR-code was signed with.
This example shows how to search for secure Metadata signature text.
using(Signaturesignature=newSignature("MetadataEncryptedText.docx")){// setup key and passphrasestringkey="1234567890";stringsalt="1234567890";// create data encryptionIDataEncryptionencryption=newSymmetricEncryption(SymmetricAlgorithmType.Rijndael,key,salt);MetadataSearchOptionsoptions=newMetadataSearchOptions(){DataEncryption=encryption};// search for signatures in documentList<WordProcessingMetadataSignature>signatures=signature.Search<WordProcessingMetadataSignature>(options);Console.WriteLine("\nSource document contains following signatures.");// get required metadata signaturesWordProcessingMetadataSignaturemdAuthor=signatures.FirstOrDefault(p=>p.Name=="Author");if(mdAuthor!=null){Console.WriteLine("Metadata signature found. Name : {0}. Value: {1}",mdAuthor.Name,mdAuthor.GetData<string>());}// get required metadata signaturesWordProcessingMetadataSignaturemdDocId=signatures.FirstOrDefault(p=>p.Name=="DocumentId");if(mdDocId!=null){Console.WriteLine("Metadata signature found. Name : {0}. Value: {1}",mdDocId.Name,mdDocId.GetData<string>());}}
More resources
GitHub Examples
You may easily run the code above and see the feature in action in our GitHub examples: