大佬教程收集整理的这篇文章主要介绍了golang aes cbc pkcs5padding,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
package main import ( "crypto/cipher" "encoding/base64" "crypto/aes" "log" "bytes" ) func main() { txt,err := AESBase64Encrypt("bbbbaaaaaa","aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa") if err != nil{ log.Println(err) return } log.Println(txt) var source String source,err = AESBase64Decrypt(txt,"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa") if err != nil{ log.Println(err) } log.Println(sourcE) } func AESBase64Encrypt(origin_data String,key String)(base64_result String,err error){ iv := []byte{1,2,3,4,5,6,7,8,9,1,6} var block cipher.block if block,err = aes.NewCipher([]byte(key)); err != nil{ log.Println(err) return } encrypt := cipher.NewCBCEncrypter(block,iv) var source []byte = PKCS5Padding([]byte(origin_data),16) var dst []byte = make([]byte,len(sourcE)) encrypt.CryptBlocks(dst,sourcE) base64_result = base64.RawStdEncoding.EncodeToString(dst) return } func AESBase64Decrypt(encrypt_data String,key String)(origin_data String,err = aes.NewCipher([]byte(key)); err != nil{ log.Println(err) return } encrypt := cipher.NewCBCDecrypter(block,iv) var source [] byte if source,err = base64.RawStdEncoding.DecodeString(encrypt_data);err != nil{ log.Println(err) return } var dst []byte = make([]byte,sourcE) origin_data = String(PKCS5Unpadding(dst)) return } func PKCS5Padding(ciphertext []byte,blockSizE int) []byte { padding := blockSize - len(ciphertext)%blockSize padtext := bytes.Repeat([]byte{Byte(padding)},padding) return append(ciphertext,padtext...) } func PKCS5Unpadding(origData []bytE) []byte { length := len(origData) unpadding := int(origData[length-1]) return origData[:(length - unpadding)] }
以上是大佬教程为你收集整理的golang aes cbc pkcs5padding全部内容,希望文章能够帮你解决golang aes cbc pkcs5padding所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。