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
(PowerBuilder) Charset Considerations when RSA Encrypting StringsWhen encrypting strings, character encoding can be an issue. Encryption algorithms operate on binary data. If for example, your string includes a character such as é, the bytes used to represent it depend on the character encoding. In an "iso" encoding such as iso-8859-1, or in a "windows" encoding, such as "windows-1252", the é is represented by a single byte. In Unicode however, whether it's utf-8 or ucs-2, the é is represented by 2 bytes. When encrypting strings, the RSA component will first convert the string to the character encoding indicated by the Charset property. When decrypting strings, the RSA component converts from the character encoding indicated by the Charset property to the application's expected charset. In VB6 for example, this would be Unicode. In C++, it's ANSI. In Java, it's utf-8.
integer li_rc oleobject loo_Rsa string ls_PublicKey integer li_Success string ls_PlainText integer li_UsePrivateKey string ls_EncryptedStr // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. loo_Rsa = create oleobject // Use "Chilkat_9_5_0.Rsa" for versions of Chilkat < 10.0.0 li_rc = loo_Rsa.ConnectToNewObject("Chilkat.Rsa") if li_rc < 0 then destroy loo_Rsa MessageBox("Error","Connecting to COM object failed") return end if // RSA public key in XML format: ls_PublicKey = "<RSAPublicKey><Modulus>of3im3mRgd2NLXIGoK6uYLg6jj0Ug2b42rnqa5Tbwz2ieFqMJqt+++x2oqLYGurlz49nt+7/785g3XYWqoka4u9c9zul6YubIjnBM72dQy7rEkEfbUxgjcxqXyjZFx+FpaxFUecLu688XEu+9UA42VKiCgcl+E7TrqnfeeYpNXc=</Modulus><Exponent>AQAB</Exponent></RSAPublicKey>" li_Success = loo_Rsa.ImportPublicKey(ls_PublicKey) // Use the utf-8 character encoding. When encrypting, the // plain text is first converted to utf-8 bytes and then // RSA encrypted. loo_Rsa.Charset = "utf-8" // Encrypt a string and return the encrypted data base64-encoded: loo_Rsa.EncodingMode = "base64" ls_PlainText = "éééé" li_UsePrivateKey = 0 ls_EncryptedStr = loo_Rsa.EncryptStringENC(ls_PlainText,li_UsePrivateKey) Write-Debug ls_EncryptedStr destroy loo_Rsa |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.