1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
| package main
import ( "bytes" "crypto/aes" "crypto/cipher" "encoding/base64" "fmt" )
func AesEncrypt(str string, key string) string { strData := []byte(str) k := []byte(key) block, _ := aes.NewCipher(k) blockSize := block.BlockSize() strData = PKCS7Padding(strData, blockSize) blockMode := cipher.NewCBCEncrypter(block, k[:blockSize]) cryted := make([]byte, len(strData)) blockMode.CryptBlocks(cryted, strData) return base64.StdEncoding.EncodeToString(cryted) }
func AesDecrypt(cryted string, key string) string { crytedByte, _ := base64.StdEncoding.DecodeString(cryted) k := []byte(key) block, _ := aes.NewCipher(k) blockSize := block.BlockSize() blockMode := cipher.NewCBCDecrypter(block, k[:blockSize]) str := make([]byte, len(crytedByte)) blockMode.CryptBlocks(str, crytedByte) str = PKCS7UnPadding(str) return string(str) }
func PKCS7Padding(ciphertext []byte, blocksize int) []byte { padding := blocksize - len(ciphertext)%blocksize padtext := bytes.Repeat([]byte{byte(padding)}, padding) return append(ciphertext, padtext...) }
func PKCS7UnPadding(strData []byte) []byte { length := len(strData) unpadding := int(strData[length-1]) return strData[:(length - unpadding)] }
func main() { str := "hello world" key := "psvmc123456789101112131415161718" fmt.Println("原字符串内容:", str) encryptCode := AesEncrypt(str, key) fmt.Println("加密后的密文:", encryptCode) decryptCode := AesDecrypt(encryptCode, key) fmt.Println("解密结果:", decryptCode) }
|