![]()  | 
  
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
 
      (Swift) DSA Generate KeyGenerates a DSA public/private key pair and saves to PEM and DER file formats (both encrypted and non-encrypted). An encrypted DSA PEM looks like this: -----BEGIN DSA PRIVATE KEY----- Proc-Type: 4,ENCRYPTED DEK-Info: DES-EDE3-CBC,9DAFD5C4CD62A5D0 QwDdp66sB0qKXQli7FbVcKL/eo3wu7kGRlV2sI8XbkNa1RTLiwnwTWDB0dqyWRQ8 ... Bx0HVfxKiNgCbL6BQEnYD+GOmMcckuj9Uhgloe/YuXCIDJBGhjUt/li3hvR/PXeC V2xxNl1XKBE88njqi+UXt4vjGVNLpvXM -----END DSA PRIVATE KEY----- 
 func chilkatTest() { // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. let dsa = CkoDsa()! // Call GenKey to generate a new DSA key. // The number of bits should be at least 1024 and a multiple // of 64. Typical values are either 1024 or 2048. // DSA key generation is compute intensive and may take // a short while to complete. var success: Bool = dsa.genKey(2048) if success != true { print("\(dsa.lastErrorText!)") return } // Extract the private and public parts to PEM or DER format // and save to files... var pemStr: String? var xmlStr: String? // First for the public key... // The public key never needs to be encrypted. // Save the public key in PEM format: pemStr = dsa.toPublicPem() // This example will not check the return value of SaveText... success = dsa.saveText(pemStr, path: "dsa_pub.pem") // Save the public key in DER format: success = dsa.toPublicDerFile("dsa_pub.der") var bPublicOnly: Bool = true // Save to XML xmlStr = dsa.toXml(bPublicOnly) success = dsa.saveText(xmlStr, path: "dsa_pub.xml") // ------------------------------------ // Now for the private key.... // ------------------------------------ // Unencrypted PEM: pemStr = dsa.toPem() success = dsa.saveText(pemStr, path: "dsa_priv.pem") // Encrypted PEM: pemStr = dsa.toEncryptedPem("myPassword") success = dsa.saveText(pemStr, path: "dsa_privEncrypted.pem") // DER: success = dsa.toDerFile("dsa_priv.der") // XML: bPublicOnly = false xmlStr = dsa.toXml(bPublicOnly) success = dsa.saveText(xmlStr, path: "dsa_priv.xml") print("Finished!") }  | 
  ||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.