Go语言实现对称加密算法AES、DES、3DES和非对称加密算法RSA

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 := aes.NewCipher(key)
    if err != nil {
        return src, err
    }
    // 密码填充
    NewSrcByte := PadPwd(srcByte, block.BlockSize()) //由于字节长度不够,所以要进行字节的填充
    fmt.Println(NewSrcB

猜你喜欢

转载自blog.csdn.net/JineD/article/details/129873616