Home - wwj-2017-1117/AES_OK GitHub Wiki

package main

import ( "bytes" "crypto/aes" "crypto/cipher" "log" "fmt" ) // AES 对称加密

// 填充数据 func padding(src []byte, blockSize int) []byte { padNum := blockSize - len(src) % blockSize pad := bytes.Repeat([]byte{byte(padNum)}, padNum) return append(src, pad...) }

// 去掉填充数据 func unpadding(src []byte) []byte { n := len(src) unPadNum := int(src[n-1]) return src[:n-unPadNum] }

// 加密 , AES加密,CBC分组模式 func encryptAES(src []byte, key []byte) ([]byte, error) { block, err := aes.NewCipher(key) if err != nil { return nil, err } src = padding(src, block.BlockSize()) blockMode := cipher.NewCBCEncrypter(block, key) blockMode.CryptBlocks(src, src) return src, nil }

// 解密, AES加密,CBC分组模式 func decryptAES(src []byte, key []byte) ([]byte, error) { block, err := aes.NewCipher(key) if err != nil { return nil, err } blockMode := cipher.NewCBCDecrypter(block, key) blockMode.CryptBlocks(src, src) src = unpadding(src) return src, nil }

func main() { d := []byte("hello,ase") /* 提示错误: crypto/aes: invalid key size 15 出现这个错误是因为key参数的长度不符合要求。根据aes.NewCipher的源代码, 长度必须是如下: 16 字节 - AES-128 24 字节 - AES-192 32 字节 - AES-256 */ key := []byte("abcdefg_87654321") fmt.Println("加密前:", string(d)) x1, err := encryptAES(d, key) if err != nil { log.Fatalln(err) } fmt.Println("加密后:", string(x1)) x2, err := decryptAES(x1, key) if err != nil { log.Fatalln(err) } fmt.Println("解密后:", string(x2)) }