GOlang AES加密 CBC 模式 使用PKCS7进行填充,IOS也是7

package main

 

import (

    "bytes"

    "crypto/aes"

    "crypto/cipher"

    "crypto/rand"

    "encoding/base64"

    "fmt"

    "io"

)

 

// 签名字符串生成

// CBC 模式

// 加密

//

// 使用PKCS7进行填充,IOS也是7

func PKCS7Padding(ciphertext []byte, blockSize int) []byte {

    padding := blockSize - len(ciphertext)%blockSize // 需要填充的数目

 

    // 只要少于256就能放到一个byte中,默认的blockSize=16(即采用16*8=128, AES-128长的密钥)

    // 最少填充1个byte,如果原文刚好是blocksize的整数倍,则再填充一个blocksize

    padtext := bytes.Repeat([]byte{byte(padding)}, padding) // 生成填充的文本

    return append(ciphertext, padtext...)

}

 

func PKCS7UnPadding(origData []byte) []byte {

    length := len(origData)

    unpadding := int

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值