Quantcast
Channel: CodeSection,代码区,网络安全 - CodeSec
Viewing all articles
Browse latest Browse all 12749

golang中crypto/aes包

0
0

aes是对称加密算法,这篇博客只介绍怎么使用golang中怎么调用标准库已封装的算法实现,如果是要学习aes算法实现,移步百度

有两个操作:加密和解密

const BlockSize = 16

功能说明:AES算法块(加密数据块)的字节长度。

package main import ( "bytes" "crypto/aes" "crypto/cipher" "log" "fmt" ) // 填充数据 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] } // 加密 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 } // 解密 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") key := []byte("hgfedcba87654321") 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)) }

Viewing all articles
Browse latest Browse all 12749