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
(Perl) Duplicate Java Secure Token CreationDemonstrates how to duplicate some Java code that creates an RSA signature to create a base64 token.
use chilkat(); # This requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. # This example duplicates the following Java code: # public X509Certificate2 cert = new X509Certificate2(@"Some path to p12/p12file_name.p12","Password_for_p12"); # # public string GenerateSignToken(double timeValidityMin){ # string equalsSign = ":="; # string timeCreated = DateTime.Now.ToString("yyyy-MM-ddTHH:mm:ss.fffzzz"); # string tokenTimeInfo = "validityTimeMinutes" + equalsSign + timeValidityMin + ";"+"timeCreated" + equalsSign + timeCreated; # string signature = SignData(tokenTimeInfo); # string secureToken = tokenTimeInfo + ";" + "signature" + equalsSign + signature; # return Base64UrlEncode(secureToken); # } # # public string SignData(string stringToSign){ # byte[] dataToSign = Encoding.UTF8.GetBytes(stringToSign); # RSACryptoServiceProvider privKey = (RSACryptoServiceProvider)cert.PrivateKey; # CspKeyContainerInfo containerInfo = new RSACryptoServiceProvider().CspKeyContainerInfo; # CspParameters cspparams = new CspParameters(containerInfo.ProviderType, containerInfo.ProviderName, privKey.CspKeyContainerInfo.KeyContainerName); # privKey = new RSACryptoServiceProvider(cspparams); # string id = CryptoConfig.MapNameToOID("SHA256"); # byte[] sign = privKey.SignData(dataToSign, id); # bool res = privKey.VerifyData(dataToSign, id, sign); # return Convert.ToBase64String(sign).Replace('+', '-').Replace('/', '_').Replace("=", ""); # } # # private static string Base64UrlEncode(string input){ # var inputBytes = Encoding.UTF8.GetBytes(input); # return Convert.ToBase64String(inputBytes).Replace('+', '-').Replace('/', '_').Replace("=", ""); # } $dt = chilkat::CkDateTime->new(); $dt->SetFromCurrentSystemTime(); $timeCreated = $dt->getAsTimestamp(1); # Such as 2019-04-01T19:35:44-05:00 print $timeCreated . "\r\n"; $sbToken = chilkat::CkStringBuilder->new(); $sbToken->Append("validityTimeMinutes:=10.0;timeCreated:="); $sbToken->Append($timeCreated); $cert = chilkat::CkCert->new(); $success = $cert->LoadPfxFile("Some path to p12/p12file_name.p12","Password_for_p12"); if ($success != 1) { print $cert->lastErrorText() . "\r\n"; exit; } $rsa = chilkat::CkRsa->new(); $success = $rsa->SetX509Cert($cert,1); if ($success != 1) { print $rsa->lastErrorText() . "\r\n"; exit; } $rsa->put_EncodingMode("base64url"); $signature = $rsa->signStringENC($sbToken->getAsString(),"sha256"); if ($rsa->get_LastMethodSuccess() == 0) { print $rsa->lastErrorText() . "\r\n"; exit; } $sbToken->Append(";signature:="); $sbToken->Append($signature); # Base64URL encode the result $sbToken->Encode("base64url","utf-8"); $token = $sbToken->getAsString(); print $token . "\r\n"; |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.