
Flutter项目AES加密实现详解
本文演示如何在Flutter项目中复现一段JavaScript AES加密代码的功能。该JavaScript代码使用CryptoJS库进行AES加密,采用CBC模式和PKCS7填充。我们将使用Flutter的encrypt库实现等效功能。
原始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();
}这段JavaScript代码使用CryptoJS库,密钥和初始化向量(IV)分别为'key'和'iv',加密模式为CBC,填充方式为PKCS7。
立即学习“Java免费学习笔记(深入)”;
等效Flutter Dart代码:
import 'package:encrypt/encrypt.dart';
String encryptAes(String plainText) {
    const key = 'ihaierForTodoKey';
    const iv = 'ihaierForTodo_Iv';
    final key = Key.fromUtf8(key);
    final iv = IV.fromLength(16); // 使用fromLength生成16字节的IV,与CryptoJS的处理方式更一致。
    final encrypter = Encrypter(AES(key, mode: AESMode.cbc));
    final encrypted = encrypter.encrypt(plainText, iv: iv);
    return encrypted.base64;
}这段Dart代码使用Flutter的encrypt库实现AES加密。密钥和IV与JavaScript代码不同,需要根据实际情况调整。  关键在于使用IV.fromLength(16) 生成一个16字节的IV,这与CryptoJS的处理方式更加一致,确保加密结果的兼容性。 请确保在pubspec.yaml文件中添加encrypt依赖。
请注意,JavaScript代码中的密钥和IV长度可能与Dart代码中的不同,这可能会导致加密结果不一致。  建议仔细检查密钥和IV的长度和内容,以确保与JavaScript代码完全匹配。  如果密钥和IV长度不匹配,可能会导致填充错误。  使用IV.fromLength(16)可以确保IV长度始终为16字节,提高兼容性。
以上就是Flutter如何实现与JavaScript CryptoJS AES加密等效的功能?的详细内容,更多请关注php中文网其它相关文章!
 
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
 
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号