1. 对称加密算法
1.1 特点
加密和解密使用的是同一个密钥,数据私密性双向保证,也就是加密和解密都不能泄露密码。
1.2 优缺点
优点:加密效率高,适合大些的数据加密
缺点:安全性相对非对称低
1.3 go语言实现对称加密算法
1.3.1 AES
AES-128:key长度16 字节
AES-192:key长度24 字节
AES-256:key长度32 字节
var key []byte = []byte("hallenhallenhall")
// 填充密码长度
func PadPwd(srcByte []byte, blockSize int) []byte {
padNum := blockSize - len(srcByte)%blockSize
ret := bytes.Repeat([]byte{byte(padNum)}, padNum)
srcByte = append(srcByte, ret...)
return srcByte
}
// 加密
func AesEncoding(src string) (string, error) {
srcByte := []byte(src)
fmt.Println(srcByte)
// safer
block, err :