首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何将AES仅与passpharse一起使用

如何将AES仅与passpharse一起使用
EN

Stack Overflow用户
提问于 2019-05-29 01:54:12
回答 1查看 100关注 0票数 1

我正在开发应用程序,在android版本完成之后,我已经使用swift 5启动了ios版本。我正在使用我的android版本中的一个函数wish是用java编写的,并且使用这个函数,我使用aes-256-cbc算法加密/解密纯文本。

如何在CryptoSwift中使用此方法?

代码语言:javascript
复制
    // Java Code

    public class EncryptionDecryption {
    String strResult;

    public  String Encrypt(String text, String key) throws Exception {
        Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
        byte[] keyBytes = new byte[16];
        byte[] b = key.getBytes("UTF-8");
        int len = b.length;
        if (len > keyBytes.length)
            len = keyBytes.length;
        System.arraycopy(b, 0, keyBytes, 0, len);
        SecretKeySpec keySpec = new SecretKeySpec(keyBytes, "AES");
        IvParameterSpec ivSpec = new IvParameterSpec(keyBytes);
        cipher.init(Cipher.ENCRYPT_MODE, keySpec, ivSpec);

        byte[] results = cipher.doFinal(text.getBytes("UTF-8"));
        Log.v("GET Result from  final:", results.toString());
        strResult = Base64.encodeToString(results, 1);
        return strResult;
    }


    public String Decrypt(String text, String key) throws Exception {
        Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); 

        byte[] keyBytes = new byte[16];
        byte[] b = key.getBytes("UTF-8");
        int len = b.length;
        if (len > keyBytes.length)
            len = keyBytes.length;
        System.arraycopy(b, 0, keyBytes, 0, len);
        SecretKeySpec keySpec = new SecretKeySpec(keyBytes, "AES");
        IvParameterSpec ivSpec = new IvParameterSpec(keyBytes);
        cipher.init(Cipher.DECRYPT_MODE, keySpec, ivSpec);
        byte[] results = new byte[text.length()];
        //BASE64Decoder decoder = new BASE64Decoder();
        try {
            results = cipher.doFinal(Base64.decode(text, Base64.DEFAULT));
        } catch (Exception e) {
            Log.i("Error in Decryption", e.toString());
        }
        return new String(results, "UTF-8");
    }

    }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-06-03 06:20:11

以下是解决方案

代码语言:javascript
复制
import UIKit
import CryptoSwift

class AES : NSObject {

    public static func encrypt(text:String) -> String{

        var salted = Data.init(count: 0)
        var dx = Data.init(count: 0)
        let salt = self.randomData(ofLength: 8)
        let passpharse = "passpharse".bytes
        let passAndSalt = passpharse + salt
        while( salted.count < 48){
            dx = MD5(messageData: dx + Data.init(_: passAndSalt))
            salted += dx
        }

        let iv = salted.subdata(in: 32..<48)
        let key = salted.subdata(in: 0..<32)

        let bytesIV = [UInt8](iv as Data)
        let bytesKey = [UInt8](key as Data)

        do {
            let encrypted = try AES(key: bytesKey, blockMode: CBC(iv: bytesIV), padding: .pkcs5)
            let cipherText = try! encrypted.encrypt(text.bytes)
            let saltData = "Salted__".bytes
            let finalData = saltData + salt + cipherText
            return finalData.toBase64()!
        } catch {
            return ""
        }

    }

    private static func randomData(ofLength length: Int) -> Array<UInt8> {
        var bytes = [UInt8](repeating: 0, count: length)
        let status = SecRandomCopyBytes(kSecRandomDefault, length, &bytes)
        if status == errSecSuccess {
            return bytes
        }
        return Data.init(count: 0).bytes
    }


    private static func MD5(messageData: Data) -> Data {
        let length = Int(CC_MD5_DIGEST_LENGTH)
        //let messageData = string.data(using:.utf8)!
        var digestData = Data(count: length)

        _ = digestData.withUnsafeMutableBytes { digestBytes -> UInt8 in
            messageData.withUnsafeBytes { messageBytes -> UInt8 in
                if let messageBytesBaseAddress = messageBytes.baseAddress, let digestBytesBlindMemory = digestBytes.bindMemory(to: UInt8.self).baseAddress {
                    let messageLength = CC_LONG(messageData.count)
                    CC_MD5(messageBytesBaseAddress, messageLength, digestBytesBlindMemory)
                }
                return 0
            }
        }
        return digestData
    }

}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56347678

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档