加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

golang aes cbc pkcs5padding

发布时间:2020-12-16 18:13:38 所属栏目:大数据 来源:网络整理
导读:package mainimport ( "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 sour
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)]
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读