2017-09-23 2 views
0

J'essaye de crypter le nom d'utilisateur et le mot de passe et l'envoyer à un site Web avec RSA. J'ai cherché sur le web et n'ai rien trouvé. -je obtenir la clé publique d'un serveur Web .Net en XML formel comme celui-ci:Chiffrer en utilisant RSA de Swift à C#

<RSAKeyValue> 
<Modulus>vB/j1viHNHdSSnD1JwrZKu93GZtXO/oQAzp90w/QRQC7s7RO4PhTcW3ADOUVB1+BlmbaFsEreNUAOV5P4aZh+68T+InwmU1javFsGkjCcVoQO/uEpp2zjrM9Eh84OPaKH429GVmdfTgUj0YbmYVanM3HX4byMH25DKQD687b7x8= 
</Modulus> 
<Exponent>AQAB</Exponent> 
</RSAKeyValue> 

donc je dois chiffrer avec cette clé, je suis avec XCode 8 et Swift 3. Avec .Net C · est très facile.

RSACryptoServiceProvider encryptKey = new RSACryptoServiceProvider(); 
UnicodeEncoding encoding = new UnicodeEncoding(); 
encryptKey.FromXmlString(XML PublicKey); 
byte[] usr = encryptKey.Encrypt(encoding.GetBytes(txtUser.Text),false); 
byte[] pwd = encryptKey.Encrypt(encoding.GetBytes(txtPassword.Text),false); 

¿Est-ce que quelqu'un peut m'aider s'il vous plaît? grâce

MIS À JOUR

i essayer ce code, mais avec publicKey a été généré sous Mac OS excellent travail, mais avec la clé publique je suis arrivé de serveur ne fonctionne pas, je ne sais pas pourquoi? @Charles Srstka

let pubKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDzZtW7ETOkJGTwN/4adYI5oQZ7U7EPzfDtpZTf+cQ9zAcmcC6g6uAC6KuovBSsigcUNzw3s2eNh0RvYBl6ipJ71hH1awTBwVEWo4fl7uIqdpBjwvO1wWXg9UifpvSsV3GPff9YqMvuggDznOGc20CvsXusQKt9dDx8ESxP6yjqiwIDAQAB" 
let keyData = NSData(base64Encoded: pubKey, options: NSData.Base64DecodingOptions.ignoreUnknownCharacters)    
var dict: [NSString: AnyObject] = [ 
     kSecClass: kSecClassKey, 
     kSecAttrKeyType: kSecAttrKeyTypeRSA, 
     kSecAttrKeySizeInBits: pubKey.utf8.count as AnyObject, 
     kSecAttrKeyClass: kSecAttrKeyClassPublic, 
     kSecAttrApplicationTag: "me.lhu" as AnyObject, 
     kSecValueData: keyData as AnyObject, 
     kSecReturnRef: true as AnyObject 
];    
SecItemDelete(dict as CFDictionary) 
var err = SecItemAdd(dict as CFDictionary, nil); 
if ((err != noErr)) { 
    print("error loading public key"); 
}   
var resultData: SecKey? = nil 
var result: AnyObject? 
err = SecItemCopyMatching(dict as CFDictionary, &result) 
if err == noErr, let keyRef as! SecKey {  
    let plaintext = tf_taikhoan.text      
    let plaintextLen = plaintext?.lengthOfBytes(using: String.Encoding.utf8) 
    let plaintextBytes = [UInt8](plaintext!.utf8)      
    var encryptedLen: Int = SecKeyGetBlockSize(keyRef) 
    var encryptedBytes = [UInt8](repeating: 0, count: encryptedLen)      
    err = SecKeyEncrypt(keyRef, SecPadding.PKCS1, plaintextBytes, plaintextLen!, &encryptedBytes, &encryptedLen); 
    if (err != noErr) { 
     print(encryptedBytes); 
    } 
} 
+0

@El Tomate Je pense que c'est son code C#, pas Swift. –

+0

mon côté client est iOS swift et le côté serveur est WebAPI C# @CharlesSrstka –

Répondre

0

Si vous pouvez exiger macOS 10,12 ou iOS 10, utilisez les SecKey API:

https://developer.apple.com/library/content/documentation/Security/Conceptual/CertKeyTrustProgGuide/Encryption.html

Si vous devez supporter les anciennes versions de MacOS ou iOS, vous pouvez faire le chiffrement et le déchiffrement sur iOS/Mac OS à l'aide de la sécurité, pour Transforms que vous pouvez trouver la documentation ici:

https://developer.apple.com/library/content/documentation/Security/Conceptual/SecTransformPG/EncryptionandDecryption/EncryptionandDecryption.html#//apple_ref/doc/uid/TP40010801-CH3-SW1