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,0,1,2,3,4,5,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 error){
    iv := []byte{1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6}
    var block cipher.Block
    if block, 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, len(source))
    encrypt.CryptBlocks(dst, 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)]
}

转载于:https://my.oschina.net/zdglf/blog/912842

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值