密码学家的工具箱(golang代码实现)

本文参考《图解密码技术》第三版


   密码学家的工具箱,指六种常用加密方式包括 对称密码、非对称密码、单向散列函数、消息认证码、数字签名、伪随机数生成器。堪称六大杀器,现代社会的信息安全皆基于此。本文用go语言代码实现六种工具的具体应用。
在这里插入图片描述



对称密码

是指加密解密时用同一个秘钥,下面代码采用AES进行加解密,私钥长度只支持128,192,256位的字节数组。
在这里插入图片描述
AES加解密的代码应用:

package main

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

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
}

func main() {
   
	//私钥长度只支持128 192 256位的任意字节数组
	var aeskey = []byte("这就是私钥,自己定义呦.")
	fmt.Println("私钥:", string(aeskey))
	fmt.Printf("私钥长度:%d字节\n", len(aeskey))
	pass := []byte("罗小黑战记大电影今天上映了,真好看,快去看啊")
	fmt.Println("原文:", string(pass))
	xpass, err := AesEncrypt(pass, aeskey)
	if err != nil {
   
		fmt.Println(err)
		return
	}
	fmt.Println("==============进行加密==============")
	fmt.Printf("加密信息:%x\n", xpass)
	fmt.Println(
  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值