AES加密相关

AES是一种对称加密算法,使用相同的密钥进行加密和解密。关键参数包括:16、24或32字节的密钥,加密轮数与位数相关;初始向量(IV)用于增加安全性,必须随机;填充模式确保输入明文是16字节的倍数;加密模式如ECB、CBC等,其中CBC相对更安全。本文以Go语言展示了AES256-CBC-PKCS7模式的实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

AES是一种对称加密算法,即用同一把密钥进行加密与解密。AES加密有以下几个参数需要注意:

1.key
AES要求密钥具有16byte、24byte或者32byte,位数越高,加密强度越大,加密轮数依次为10、12、14轮。以128位密钥为例,密钥首先扩展为44个字(32位),前4个字与明文进行一次异或操作。后面40个字分成10组,分别在10轮加密中进行数据异或操作。

2.IV
初始向量,其作用是对输入明文进行,加密解密需要同样的IV。IV也需要通过随机函数产生以保证安全。

3.padding,填充模式。
AES对明文进行分组加密,每个分组为16字节,因此输入明文数据要进行字节填充,以符合整数倍16字节大小。常见的填充模式有:

4.加密模式
有ECB、CBC、CFB等,其中ECB安全性较差。

下面以Go为例,展示AES256-CBC-PKCS7模式下的加密与解密:

package main

import (
	"bytes"
	"crypto/aes"
	"crypto/cipher"
	"fmt"
)

// 输入明文和密钥,输出AES密文
func AESEncrypt(plainText, key, iv []byte) ([]byte, error) {
   
	block, err := aes.NewCipher(key)
	if err != nil {
   
		return nil, err
	}

	mode :=
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值