Как использовать mcrypt в swift с шифром и режимом? - PullRequest
0 голосов
/ 13 февраля 2019

Я пытаюсь использовать mcrypt в моем коде Swift, но все методы не работают.Это код JS для дешифрования:

 decrypt(data: string): Object {
if (typeof data !== 'string') {
  return data;
}
try {
  const bin = this.hex2bin(data);
  const message = mcrypt.Decrypt(bin, this.data.iv, this.data.key, this.data.cipher, this.data.mode);
  data = JSON.parse(atob(message.replace(/[^a-z\d+=/]/gi, '')));
} catch (e) {
  console.error('decryption error', e, data);
}
return data;}

и вот мой код, использующий модуль CryptoSwift в качестве расширения структуры String:

  func aesDecrypt() throws -> String {

    var result = NSString()
    do {
        let dec: [UInt8]
        let key = Array("Nt20K855Lb39Bc71Nt20K855Lb39Bc71".utf8)
        let iv = Array("S49t62H102k71R3a".utf8)
        let data = self.data(using: String.Encoding.utf8)

        if(data != nil) {
            dec = try  AES(key: key, blockMode: CBC(iv: iv), padding: .pkcs7).decrypt(data!.bytes)

        } else {
            dec = []
        }
        let decData = NSData(bytes: dec, length: Int(dec.count))
        result = NSString(data: decData as Data, encoding: String.Encoding.utf8.rawValue)!
    } catch let error as NSError {
        print("\n\nDencryption error\(error.localizedDescription)")
    }
    return String(result)
} 

Как я могу сделать эту расшифровку в моем проекте Swift

...