脚本之家

电脑版
提示:原网页已由神马搜索转码, 内容由www.jb51.net提供.
您的位置:首页软件编程Rust语言→ Rust AES加解密

Rust实现AES加解密详解

  更新时间:2022年10月26日 14:06:22  作者:Zhou T.x. 
这篇文章主要为大家详细介绍了如何利用Rust语言实现AES加解密算法,文中的示例代码讲解详细,具有一定的借鉴价值,需要的可以了解一下

一、选择使用 rust-crypto

rust-crypto 官方相关站点

crates.io

https://crates.io/crates/rust-crypto

repository

https://github.com/DaGenix/rust-crypto

documentation (以0.2.36为例)

https://docs.rs/rust-crypto/0.2.36

二、Cargo.toml 文件

[dependencies]
rust-crypto = "0.2.36"

三、工具类

说明:这里使用的是AES256/CBC/Pkcs加解密格式。

因此,key的长度为 256bits (32Bytes) iv的长度为128bits (16Bytes)

1、加密

/// Encrypt a buffer with the given key and iv using AES256/CBC/Pkcs encryption.
fn aes256_cbc_encrypt(
data: &[u8],
key: &[u8; 32],
iv: &[u8; 16],
) -> Result<Vec<u8>, SymmetricCipherError> {
let mut encryptor = aes::cbc_encryptor(
KeySize256,
key, iv,
PkcsPadding,
);
let mut buffer = [0; 4096];
let mut write_buffer = RefWriteBuffer::new(&mut buffer);
let mut read_buffer = RefReadBuffer::new(data);
let mut final_result = Vec::new();
loop {
let result = encryptor.encrypt(&mut read_buffer, &mut write_buffer, true)?;
final_result.extend(write_buffer.take_read_buffer().take_remaining().iter().map(|&i| i));
match result {
BufferUnderflow => break,
_ => continue,
}
}
Ok(final_result)
}

2、解密

/// Decrypt a buffer with the given key and iv using AES256/CBC/Pkcs encryption.
fn aes256_cbc_decrypt(
data: &[u8],
key: &[u8; 32],
iv: &[u8; 16],
) -> Result<Vec<u8>, SymmetricCipherError> {
let mut decryptor = aes::cbc_decryptor(
KeySize256,
key, iv,
PkcsPadding,
);
let mut buffer = [0; 4096];
let mut write_buffer = RefWriteBuffer::new(&mut buffer);
let mut read_buffer = RefReadBuffer::new(data);
let mut final_result = Vec::new();
loop {
let result = decryptor.decrypt(&mut read_buffer, &mut write_buffer, true)?;
final_result.extend(write_buffer.take_read_buffer().take_remaining().iter().map(|&i| i));
match result {
BufferUnderflow => break,
_ => continue,
}
}
Ok(final_result)
}

3、测试样例

3.1、生成随机key和iv

因为仅用作测试,所以才使用随机key和iv,应用场景注意使用固定值!

这里我们使用的crate是rand。

首先在Cargo.toml中引入:

[dependencies]
rand = "0.8.4"

3.2、编写测试用例

#[test]
fn test_aes256_cbc() {
use rand::{RngCore, rngs::OsRng};
let mut rng = OsRng::default();
let mut key = [0; 32];
let mut iv = [0; 16];
rng.fill_bytes(&mut key);
rng.fill_bytes(&mut iv);
let data = "Hello, world!";
let encrypted_data = aes256_cbc_encrypt(data.as_bytes(), &key, &iv).unwrap();
let decrypted_data = aes256_cbc_decrypt(encrypted_data.as_slice(), &key, &iv).unwrap();
let result = str::from_utf8(decrypted_data.as_slice()).unwrap();
assert_eq!(data, result);
println!("{}", result);
}

最后,执行测试用例,测试成功!

到此这篇关于Rust实现AES加解密详解的文章就介绍到这了,更多相关Rust AES加解密内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

    • JSON在Web开发中被广泛应用于数据交换,本文主要介绍了Rust语言操作JSON,包括序列化、反序列化、JSON创建等多个方面,具有一定的参考价值,感兴趣的可以了解一下
      2024-03-03
    • 在 Rust 项目中,可以使用 mod 关键字将一个文件夹或一个 rs 文件作为一个模块引入到当前文件中,本文给大家介绍rust多个mod文件引用和文件夹mod使用注意事项小结,感兴趣的朋友跟随小编一起看看吧
      2024-03-03
    • Rust 是一门注重安全性和性能的现代编程语言,其中结构体和枚举是其强大的数据类型之一,了解结构体和枚举的概念及其高级功能,将使你能够更加灵活和高效地处理数据,本文将深入探讨 Rust 中的结构体和枚举,并介绍它们的用途和高级功能
      2023-10-10
    • 这篇文章主要为大家介绍了Rust中的panic定义及触发条件详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
      2023-04-04
    • 裸指针是一个不包含所有权和借用关系的原始指针,它们与常规指针相比没有任何限制和保护措施,这篇文章主要介绍了Rust裸指针的安全性实例,需要的朋友可以参考下
      2023-05-05
    • 这篇文章主要为大家详细介绍了Rust中的枚举和模式匹配的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
      2024-01-01
    • RUST提供了一系列的功能来帮助我们管理代码,包括决定哪些细节是暴露的、哪些细节是私有的,以及不同的作用域的命名管理,这篇文章主要介绍了rust 包模块组织结构的相关知识,需要的朋友可以参考下
      2023-12-12
    • 这篇文章主要为大家介绍了Rust切片与Go的区别探索,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
      2024-01-01
    • 这篇文章主要介绍了用rust 写一个jar包 class冲突检测工具 的相关资料,需要的朋友可以参考下
      2023-05-05
    • 这篇文章主要为大家介绍了Rust 配置文件内容及使用全面讲解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
      2023-10-10

    最新评论