密码技术--国密SM4分组密码算法及Go语言应用

SM4对称加密算法

SM4是我国采用的一种分组密码标准,有国家密码局与2012年3月21日发布,秘钥长度和分组长度为128位。

go语言中应用

简单版本:其函数接口中已实现分组密码底层接口的调用

func sm4Sample(){
	src := []byte("这是对称加密SM4的CBC模式加解密测试")
	key := []byte("1q2w3e4r5t6y7u8i")
	cipherText, err := sm4.Sm4Cbc(key, src, true)
	if err != nil {
		panic(err)
	}
	plainText, err := sm4.Sm4Cbc(key, cipherText, false)
	if err != nil {
		panic(err)
	}
	flag := bytes.Equal(src, plainText)
	fmt.Println("SM4快速实现加解密,数据填充标准为pksc7,是否解密成功:", flag)
} 

复杂版本:自己实现数据填充和分组密码底层接口的调用

package main

import (
	"crypto/cipher"
	"github.com/tjfoc/gmsm/sm4"
)

//明文数据填充
func paddingLastGroup(plainText []byte, blockSize int) []byte {
	//1.计算最后一个分组中明文后需要填充的字节数
	padNum := blockSize - len(plainText)%blockSize
	//2.将字节数转换为byte类型
	char := []byte{byte(padNum)}
	//3.创建切片并初始化
	newPlain := bytes.Repeat(char, padNum)
	//4.将填充数据追加到原始数据后
	newText := append(plainText, newPlain...)

	return newText
}

//去掉明文后面的填充数据
func unpaddingLastGroup(plainText []byte) []byte {
	//1.拿到切片中的最后一个字节
	length := len(plainText)
	lastChar := plainText[length-1]
	//2.将最后一个数据转换为整数
	number := int(lastChar)
	return plainText[:length-number]
}

func sm4Encrypt (plainText, key []byte) []byte {
	block, err := sm4.NewCipher(key)
	if err != nil {
		panic(err)
	}
	paddData := paddingLastGroup(plainText, block.BlockSize())
	iv := []byte("12345678qwertyui")
	blokMode := cipher.NewCBCEncrypter(block, iv)
	cipherText := make([]byte, len(paddData))
	blokMode.CryptBlocks(cipherText, paddData)
	return cipherText
}

func sm4Dectypt(cipherText, key []byte) []byte {
	block, err := sm4.NewCipher(key)
	if err != nil {
		panic(err)
	}
	iv := []byte("12345678qwertyui")
	blockMode := cipher.NewCBCDecrypter(block, iv)
	blockMode.CryptBlocks(cipherText, cipherText)
	plainText := unpaddingLastGroup(cipherText)
	return plainText
}

func main(){
	src := []byte("这是对称加密SM4的CBC模式加解密测试")
	key := []byte("1q2w3e4r5t6y7u8i")
	cipherText := sm4Encrypt(src, key)
	plainText := sm4Dectypt(cipherText, key)
	flag := bytes.Equal(src, plainText)
	fmt.Println("解密是否成功:", flag)
} 
```## 最后
从时代发展的角度看,网络安全的知识是学不完的,而且以后要学的会更多,同学们要摆正心态,既然选择入门网络安全,就不能仅仅只是入门程度而已,能力越强机会才越多。

因为入门学习阶段知识点比较杂,所以我讲得比较笼统,大家如果有不懂的地方可以找我咨询,我保证知无不言言无不尽,需要相关资料也可以找我要,我的网盘里一大堆资料都在吃灰呢。

干货主要有:

①1000+CTF历届题库(主流和经典的应该都有了)

②CTF技术文档(最全中文版)

③项目源码(四五十个有趣且经典的练手项目及源码)

④ CTF大赛、web安全、渗透测试方面的视频(适合小白学习)

⑤ 网络安全学习路线图(告别不入流的学习)

⑥ CTF/渗透测试工具镜像文件大全

⑦ 2023密码学/隐身术/PWN技术手册大全

如果你对网络安全入门感兴趣,那么你需要的话可以点击这里**👉**[网络安全重磅福利:入门&进阶全套282G学习资源包免费分享!](https://mp.weixin.qq.com/s/BWb9OzaB-gVGVpkm161PMw)

扫码领取

<img src="https://hnxx.oss-cn-shanghai.aliyuncs.com/official/1678694737820.png?t=0.6334725112165747" />
  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值