Search for embedded object with custom encryption of QR Code signatures
Search for embedded object with custom encryption of QR Code signatures
Leave feedback
On this page
GroupDocs.Signature provides following abilities to search for embedded data objects in QR-code signatures (QrCodeSignature) that were encrypted with custom encryption.
ability to search for embedded custom objects into metadata and decrypt them to original source values
ability to search for custom encrypted QR-code signature and decrypt it
Here are the steps to search and decrypt previously encrypted text of QR-Code and decrypt custom object from QR-Code signature with GroupDocs.Signature API:
Implement (use) custom data encryption class that implements IDataEncryption interface.
This example shows how to specify custom serialization class. This class could be implemented also as Attribute (optional) to specify as class attribute.
// Define class that implements IDataEncryption interface// Class could inherits Attribute to use it with class definitionpublicclassCustomXOREncryption:IDataEncryption{/// <summary>/// Gets or sets non empty key for encryption (at least one character)/// </summary>publicintKey{get;set;}/// <summary>/// Encode method to encrypt string./// </summary>/// <param name="source">Source string to encode.</param>/// <returns>Returns enccrypted string</returns>publicstringEncode(stringsource){returnProcess(source);}/// <summary>/// Decode method to obtain decrypted string./// </summary>/// <param name="source">Source string to decode.</param>/// <returns>Returns decrypted string</returns>publicstringDecode(stringsource){returnProcess(source);}/// <summary>/// Using XOR operation get encoded / decoded string/// </summary>/// <param name="source"></param>/// <returns></returns>privatestringProcess(stringsource){StringBuildersrc=newStringBuilder(source);StringBuilderdst=newStringBuilder(src.Length);charchTmp;for(intindex=0;index<src.Length;++index){chTmp=src[index];chTmp=(char)(chTmp^this.Key);dst.Append(chTmp);}returndst.ToString();}}
Definition of class
This example shows how to define custom class for serialization.
Search for embedded custom objects in QR-code signatures
This example shows how to decrypt previously embedded encrypted custom objects into QrCodeSignature contains method GetData to retrieve object
// instantiating the signature objectusing(Signaturesignature=newSignature("signed.pdf")){// setup search optionsQrCodeSearchOptionssearchOptions=newQrCodeSearchOptions();// specify as true to search all pages of a documentsearchOptions.AllPages=true;searchOptions.DataEncryption=newCustomXOREncryptionAttribute();// search documentList<QrCodeSignature>signatures=signature.Search<QrCodeSignature>(searchOptions);// output signaturesforeach(QrCodeSignatureqrCodeSignatureinsignatures){if(qrCodeSignature!=null){DocumentSignatureDatadocSignature=qrCodeSignature.GetData<DocumentSignatureData>();if(docSignature!=null){Console.WriteLine("Found DocumentSignature: #{0} by {1} from {2} DataFactor = {3}",docSignature.ID,docSignature.Author,docSignature.Signed,docSignature.DataFactor.ToString("N2"));}}}}
More resources
GitHub Examples
You may easily run the code above and see the feature in action in our GitHub examples: