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
(VBScript) Duplicate Java Secure Token CreationDemonstrates how to duplicate some Java code that creates an RSA signature to create a base64 token.
Dim fso, outFile Set fso = CreateObject("Scripting.FileSystemObject") 'Create a Unicode (utf-16) output text file. Set outFile = fso.CreateTextFile("output.txt", True, True) ' 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("=", ""); ' } ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.CkDateTime") set dt = CreateObject("Chilkat.CkDateTime") success = dt.SetFromCurrentSystemTime() timeCreated = dt.GetAsTimestamp(1) ' Such as 2019-04-01T19:35:44-05:00 outFile.WriteLine(timeCreated) ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder") set sbToken = CreateObject("Chilkat.StringBuilder") success = sbToken.Append("validityTimeMinutes:=10.0;timeCreated:=") success = sbToken.Append(timeCreated) ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Cert") set cert = CreateObject("Chilkat.Cert") success = cert.LoadPfxFile("Some path to p12/p12file_name.p12","Password_for_p12") If (success <> 1) Then outFile.WriteLine(cert.LastErrorText) WScript.Quit End If ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Rsa") set rsa = CreateObject("Chilkat.Rsa") success = rsa.SetX509Cert(cert,1) If (success <> 1) Then outFile.WriteLine(rsa.LastErrorText) WScript.Quit End If rsa.EncodingMode = "base64url" signature = rsa.SignStringENC(sbToken.GetAsString(),"sha256") If (rsa.LastMethodSuccess = 0) Then outFile.WriteLine(rsa.LastErrorText) WScript.Quit End If success = sbToken.Append(";signature:=") success = sbToken.Append(signature) ' Base64URL encode the result success = sbToken.Encode("base64url","utf-8") token = sbToken.GetAsString() outFile.WriteLine(token) outFile.Close |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.