2个版本
0.1.2 | 2024年1月15日 |
---|---|
0.1.0 | 2023年9月3日 |
0.0.0 |
|
#1012 in 加密学
19KB
385 代码行
sm4-gcm
加密解密测试代码
fn main() {
let key = Sm4Key([0u8; 16]);
let nonce = [0u8; 12];
let plaintext = b"Hello World!";
let ciphertext = sm4_gcm::sm4_gcm_encrypt(&key, &nonce, plaintext);
println!("Encrypted: {}", hex::encode(&ciphertext));
let decrypted = sm4_gcm::sm4_gcm_decrypt(&key, &nonce, &ciphertext).unwrap();
println!("Decrypted: {}", String::from_utf8_lossy(&decrypted));
}
生成测试向量BC测试代码
public static void encryptGcmNoPadding(String key, String data, String nonce, String associatedData) throws Exception {
Cipher cipher = Cipher.getInstance("SM4/GCM/NoPadding", BouncyCastleProvider.PROVIDER_NAME);
Key sm4Key = new SecretKeySpec(Bytes.fromHex(key).bytes(), "SM4");
byte[] iv = Bytes.fromHex(nonce).bytes();
GCMParameterSpec s = new GCMParameterSpec(128, iv);
cipher.init(Cipher.ENCRYPT_MODE, sm4Key, s);
if (associatedData != null && associatedData.length() > 0) {
cipher.updateAAD(Bytes.fromHex(associatedData).bytes());
}
byte[] aa = cipher.doFinal(data.getBytes(StandardCharsets.UTF_8));
System.out.println(Bytes.from(aa).asHex());
}
基准测试 @MacBook Pro (Retina, 15英寸, 2013年晚些时候/2 GHz 四核英特尔酷睿i7)
$ cargo run --release --example bench
SM4/GCM encrypt : 65.69 M/s
依赖项
~555KB
~11K SLoC