Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Lianja) Aadhaar Paperless Offline e-kycOpens an encrypted .zip containing Aadhaar Paperless Offline e-KYC XML. Gets the XML and validates the digital signature. Then computes the hash for the mobile number and Email ID. For more information, see https://uidai.gov.in/ecosystem/authentication-devices-documents/about-aadhaar-paperless-offline-e-kyc.html
// This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // Open the .zip containing the Aadhaar Paperless Offline e-KYC XML. // The .zip is encrypted using the "Share Phrase". loZip = createobject("CkZip") llSuccess = loZip.OpenZip("qa_data/xml_dsig/offline_paperless_kyc.zip") if (llSuccess = .F.) then ? loZip.LastErrorText release loZip return endif // The .zip should contain 1 XML file. loEntry = loZip.GetEntryByIndex(0) if (loZip.LastMethodSuccess = .F.) then ? loZip.LastErrorText release loZip return endif // To get the contents, we need to specify the Share Phrase. lcSharePhrase = "Lock@487" loZip.DecryptPassword = lcSharePhrase loBdXml = createobject("CkBinData") // The XML file will be unzipped into the bdXml object. llSuccess = loEntry.UnzipToBd(loBdXml) if (llSuccess = .F.) then ? loEntry.LastErrorText release loEntry release loZip release loBdXml return endif release loEntry // First verify the XML digital signature. loDsig = createobject("CkXmlDSig") llSuccess = loDsig.LoadSignatureBd(loBdXml) if (llSuccess <> .T.) then ? loDsig.LastErrorText release loZip release loBdXml release loDsig return endif // The UIDAI XML signature does not contain the KeyInfo, so we must load the uidai certificate // and indicate that its public key is to be used for verifying the signature. loCert = createobject("CkCert") llSuccess = loCert.LoadFromFile("qa_data/xml_dsig/uidai_auth_sign_prod_2023.cer") if (llSuccess <> .T.) then ? loCert.LastErrorText release loZip release loBdXml release loDsig release loCert return endif // Get the certificate's public key. loPubKey = loCert.ExportPublicKey() llSuccess = loDsig.SetPublicKey(loPubKey) release loPubKey // The XML in this example contains only 1 signature. llBVerifyReferenceDigests = .T. llBVerified = loDsig.VerifySignature(llBVerifyReferenceDigests) if (llBVerified = .F.) then ? loDsig.LastErrorText ? "The signature was not valid." release loZip release loBdXml release loDsig release loCert return endif ? "The XML digital signature is valid." // Let's compute the hash for the Mobile Number. // Hashing logic for Mobile Number : // Sha256(Sha256(Mobile+SharePhrase))*number of times last digit of Aadhaar number // (Ref ID field contains last 4 digits). // // Example : // Mobile: 1234567890 // Aadhaar Number:XXXX XXXX 3632 // Passcode : Lock@487 // Hash: Sha256(Sha256(1234567890Lock@487))*2 // In case of Aadhaar number ends with Zero we will hashed one time. loCrypt = createobject("CkCrypt2") loCrypt.HashAlgorithm = "sha256" loCrypt.EncodingMode = "hexlower" lcStrToHash = "1234567890Lock@487" loBdHash = createobject("CkBinData") llSuccess = loBdHash.AppendString(lcStrToHash,"utf-8") // Hash a number of times equal to the last digit of your Aadhaar number. // If the Aadhaar number ends with 0, then hash one time. // For this example, we'll just set the number of times to hash // for the case where an Aadhaar number ends in "9" lnNumTimesToHash = 9 for i = 1 to lnNumTimesToHash lcTmpStr = loCrypt.HashBdENC(loBdHash) loBdHash.Clear() loBdHash.AppendString(lcTmpStr,"utf-8") next ? "Computed Mobile hash = " + loBdHash.GetString("utf-8") // Let's get the mobile hash stored in the XML and compare it with our computed hash. loXml = createobject("CkXml") llSuccess = loXml.LoadBd(loBdXml,.T.) lcM_hash = loXml.ChilkatPath("UidData|Poi|(m)") ? "Stored Mobile hash = " + lcM_hash // Now do the same thing for the email hash: lcStrToHash = "abc@gm.comLock@487" loBdHash.Clear() llSuccess = loBdHash.AppendString(lcStrToHash,"utf-8") for i = 1 to lnNumTimesToHash lcTmpStr = loCrypt.HashBdENC(loBdHash) loBdHash.Clear() loBdHash.AppendString(lcTmpStr,"utf-8") next ? "Computed Email hash = " + loBdHash.GetString("utf-8") lcE_hash = loXml.ChilkatPath("UidData|Poi|(e)") ? "Stored Email hash = " + lcE_hash release loZip release loBdXml release loDsig release loCert release loCrypt release loBdHash release loXml |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.