zm.EncodeAES AES加密

文章目录
  1. 1. 功能
  2. 2. 语法
  3. 3. 参数
  4. 4. 返回值
  5. 5. 示例
  6. 6. 备注

功能

高级加密标准(英语:Advanced Encryption Standard,缩写:AES),是美国联邦政府采用的一种区块加密标准。属于对称加密的一种,能通过zm.DecodeAES AES解密进行解密还原, 支持AES128,AES196和AES256。

语法

结果 = zm.EncodeAES(明文, 密钥[, 高级属性])

参数

参数 数据类型 解释
明文 字符串 待加密的明文内容。
密钥 字符串 用于加密的密钥。
高级属性 可选参数,用于设置加解密模式等选项,格式为{“属性名”:”属性值”,…},详见下方表。
属性名 可选值列表 默认值 作用
mode ecb,cbc,ctr,ofb,cfb,ige,pcbc ecb 密文加密模式
padding zero,pkcs7,isoiec7816,ansix923 zero 填充方式
block 128,192,256 128 数据块
iv 任意字符串 0 iv偏移量,ecb模式不用填写,其他模式必填且要有16个字节长度。
cipherout 0,2,16,64 16 密文类型,0为原二进制字符串,2为字节数组, 16为十六进制字符串, 64为原二进制字符串Base64编码

返回值

字符串 ,返回加密后的结果,失败为null

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
Import "zm.luae" //导入插件,只需执行一次
zm.Init //初始化插件,只需执行一次

Dim text = "紫猫", pwd = "m.zimaoxy.com"
Dim s, v
s = zm.EncodeAES(text, pwd)
TracePrint "对明文", text, "使用密钥", pwd, "进行AES-ECB加密结果", s
v = zm.DecodeAES(s, pwd)
TracePrint "对密文", s, "使用密钥", pwd, "进行AES-ECB解密结果", v

s = zm.EncodeAES(text, pwd, {"cipherout":64})
TracePrint "对明文", text, "使用密钥", pwd, "进行AES加密输出Base64结果", s
v = zm.DecodeAES(s, pwd, {"cipherout":64})
TracePrint "对十六进制密文", s, "使用密钥", pwd, "进行AES解密输出Base64结果", v

s = zm.EncodeAES(text, pwd, {"mode":"cbc","iv":"1234567890abcdef"})
TracePrint "对明文", text, "使用密钥", pwd, "进行AES-CBC加密结果", s
v = zm.DecodeAES(s, pwd, {"mode":"cbc","iv":"1234567890abcdef"})
TracePrint "对十六进制密文", s, "使用密钥", pwd, "进行AES-CBC解密结果", v

备注

  • V1.1723b: 初次加入
  • V2.1828:
  • V3.1831:
    • 修改为标准AES加解密, 注意不兼容上版本的加解密结果!
    • 对密钥长度加入限制
    • 修复解密结果包含\0字符的问题