跳到主要内容

crypto 消息处理(加密,摘要)

$crypto 模块提供了对称加密(例如 AES)、非对称加密(例如 RSA)、消息摘要(例如 MD5, SHA)等支持。

let message = "未加密字符串";
log("明文: ", message);

// 密钥,由于AES等算法要求是16位的倍数,我们这里用一个16位的密钥
let key = new $crypto.Key("password12345678");
log("密钥: ", key);

// AES加密
let aes = $crypto.encrypt(message, key, "AES/ECB/PKCS5padding");
log("AES加密后二进制数据: ", aes);
log(
"AES解密: ",
$crypto.decrypt(aes, key, "AES/ECB/PKCS5padding", { output: "string" })
);

// RSA加密

// 生成RSA密钥
let keyPair = $crypto.generateKeyPair("RSA");
log("密钥对: ", keyPair);

// 使用私钥加密
let rsa = $crypto.encrypt(message, keyPair.privateKey, "RSA/ECB/PKCS1padding");
log("RSA私钥加密后二进制数据: ", rsa);

// 使用公钥解密
log(
"RSA公钥解密: ",
$crypto.decrypt(rsa, keyPair.publicKey, "RSA/ECB/PKCS1padding", {
output: "string",
})
);
// 字符串消息摘要
let message = "Hello, Autox.js";
// 输出各种消息摘要算法结果的hex值
log("字符串: ", message);
log("MD5: ", $crypto.digest(message, "MD5"));
log("SHA1: ", $crypto.digest(message, "SHA-1"));
log("SHA256: ", $crypto.digest(message, "SHA-256"));

// 输出各种消息摘要算法结果的base64值
log("MD5 [base64]: ", $crypto.digest(message, "MD5", { output: "base64" }));
log("SHA1 [base64]: ", $crypto.digest(message, "SHA-1", { output: "base64" }));
log(
"SHA256 [base64]: ",
$crypto.digest(message, "SHA-256", { output: "base64" })
);

// 文件消息摘要
let file = "/sdcard/脚本/_test_for_message_digest.js";
// 写入文件内容,提供为后续计算MD5等
$files.write(file, "Test!");
log("文件: ", file);
log("MD5: ", $crypto.digest(file, "MD5", { input: "file" }));
log("SHA1: ", $crypto.digest(file, "SHA-1", { input: "file" }));
log("SHA256: ", $crypto.digest(file, "SHA-256", { input: "file" }));