标签导航:

flutter项目中aes加密的实现

本文将探讨如何在flutter项目中实现与一段javascript代码等效的aes加密功能。 javascript代码使用cryptojs库进行aes加密,其核心逻辑是使用指定的密钥和初始化向量(iv)对输入文本进行cbc模式下的aes加密,并使用pkcs7填充方式。

javascript代码如下:

import cryptojs from 'crypto-js'
encrypt(word) {
    const key = 'key'
    const iv = 'iv'
    var _word = cryptojs.enc.utf8.parse(word),
    _key = cryptojs.enc.utf8.parse(key),
    _iv = cryptojs.enc.utf8.parse(iv)
    var encrypted = cryptojs.aes.encrypt(_word, _key, {
    iv: _iv,
    mode: cryptojs.mode.cbc,
    padding: cryptojs.pad.pkcs7
    })
    return encrypted.tostring()
}

为了在flutter中实现同样的加密效果,我们可以利用encrypt这个dart包。 以下代码片段展示了如何在flutter中使用encrypt包实现aes加密,并与上述javascript代码的功能等效:

static String encryptAes(
    String plainText,
  ) {
    const key = 'ihaierForTodoKey';
    const iv = 'ihaierForTodo_Iv';
    final _key = encrypt.Key.fromUtf8(key);
    final _iv = encrypt.IV.fromUtf8(iv);
    final encrypter = encrypt.Encrypter(encrypt.AES(_key, mode: encrypt.AESMode.cbc));

    final encrypted = encrypter.encrypt(plainText, iv: _iv);

    return encrypted.base64;
  }

这段dart代码使用了encrypt包提供的aes加密功能,指定了密钥、初始化向量以及cbc模式和pkcs7填充,最终返回base64编码的加密结果。 需要注意的是,密钥和初始化向量需要与javascript代码中保持一致,才能保证加密结果的兼容性。 密钥和iv的安全性至关重要,应妥善保管。