码迷,mamicode.com
首页 > 其他好文 > 详细

[GO]golang实现AES加解密

时间:2021-07-19 16:44:12      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:ror   ted   实现   too   ret   直接   参数   app   fun   

直接上代码:

package tools

import (
    "bytes"
    "crypto/aes"
    "crypto/cipher"
)

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)]
}

func AesEncrypt(origData, key []byte) ([]byte, error) {
    block, err := aes.NewCipher(key)
    if err != nil {
        return nil, err
    }

    blockSize := block.BlockSize()
    origData = PKCS5Padding(origData, blockSize)
    blockMode := cipher.NewCBCEncrypter(block, key[:blockSize])
    crypted := make([]byte, len(origData))
    blockMode.CryptBlocks(crypted, origData)
    return crypted, nil
}

func AesDecrypt(crypted, key []byte) ([]byte, error) {
    block, err := aes.NewCipher(key)
    if err != nil {
        return nil, err
    }

    blockSize := block.BlockSize()
    blockMode := cipher.NewCBCDecrypter(block, key[:blockSize])
    origData := make([]byte, len(crypted))
    blockMode.CryptBlocks(origData, crypted)
    origData = PKCS5UnPadding(origData)
    return origData, nil
}

AesDecrypt是解密

AesEncrypt是加密,第二个参数是设置的key,key的长度必须是16、24、32

[GO]golang实现AES加解密

标签:ror   ted   实现   too   ret   直接   参数   app   fun   

原文地址:https://www.cnblogs.com/taoshihan/p/15026240.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!