【Go】爬虫数据解密_使用Go语言实现TripleDES加密和解密


是你多么温馨的目光

教我坚毅望着前路

叮嘱我跌倒不应放弃

没法解释怎可报尽亲恩

爱意宽大是无限

请准我说声真的爱你

🎵 Beyond《真的爱你》


引言

Triple Data Encryption Standard (TripleDES 或 3DES) 是一种对称加密算法,它通过三次应用Data Encryption Standard (DES) 加密算法来提供更高的安全性。本文将介绍如何使用Go语言实现TripleDES加密和解密,包括PKCS5填充和去填充。

什么是TripleDES?

TripleDES是对称密钥加密的一个扩展版,它通过三次应用DES算法来提高安全性。使用三个不同的密钥,3DES在数据块上进行三次加密和解密操作,从而显著提高了安全性。

准备工作

在开始编写代码之前,请确保已安装Go语言环境。可以从 Go语言官方网站 下载并安装。

代码实现

以下是完整的代码实现,包括加密和解密函数,以及PKCS5填充和去填充。

go 复制代码
package main

import (
	"bytes"
	"crypto/cipher"
	"crypto/des"
	"encoding/hex"
	"fmt"
	"log"
)

// PKCS5Padding 对明文进行PKCS5填充
func PKCS5Padding(src []byte, blockSize int) []byte {
	padding := blockSize - len(src)%blockSize
	padText := bytes.Repeat([]byte{byte(padding)}, padding)
	return append(src, padText...)
}

// PKCS5UnPadding 对解密后的明文去除PKCS5填充
func PKCS5UnPadding(origData []byte) []byte {
	length := len(origData)
	unpadding := int(origData[length-1])
	return origData[:(length - unpadding)]
}

// Encrypt3DES 3DES加密
func Encrypt3DES(src, key []byte, ivs string) ([]byte, error) {
	block, err := des.NewTripleDESCipher(key)
	if err != nil {
		return nil, err
	}

	src = PKCS5Padding(src, block.BlockSize())
	iv := []byte(ivs)
	if len(iv) != block.BlockSize() {
		return nil, fmt.Errorf("IV length must be equal to block size")
	}

	blockMode := cipher.NewCBCEncrypter(block, iv)
	cipherText := make([]byte, len(src))
	blockMode.CryptBlocks(cipherText, src)

	return cipherText, nil
}

// Decrypt3DES 3DES解密
func Decrypt3DES(src, key []byte, ivs string) ([]byte, error) {
	block, err := des.NewTripleDESCipher(key)
	if err != nil {
		return nil, err
	}

	iv := []byte(ivs)
	if len(iv) != block.BlockSize() {
		return nil, fmt.Errorf("IV length must be equal to block size")
	}

	blockMode := cipher.NewCBCDecrypter(block, iv)
	blockMode.CryptBlocks(src, src)
	newText := PKCS5UnPadding(src)

	return newText, nil
}

func main() {
	key := []byte("0123456789abcdef01234567") // 24字节的密钥
	iv := "12345678"                          // 8字节的初始向量
	plaintext := "Hello, 3DES CBC Encryption!"

	// 加密
	ciphertext, err := Encrypt3DES([]byte(plaintext), key, iv)
	if err != nil {
		log.Fatalf("加密失败: %v", err)
	}
	fmt.Printf("加密后的密文: %s\n", hex.EncodeToString(ciphertext))

	// 解密
	decryptedText, err := Decrypt3DES(ciphertext, key, iv)
	if err != nil {
		log.Fatalf("解密失败: %v", err)
	}
	fmt.Printf("解密后的明文: %s\n", decryptedText)
}

代码说明

PKCS5填充和去填充

PKCS5Padding:将数据填充到块大小的倍数。

PKCS5UnPadding:去除填充的数据。

3DES加密

Encrypt3DES:使用3DES加密算法对数据进行加密。包括PKCS5填充,创建3DES密码块,设置CBC模式加密器,并进行加密。

3DES解密

Decrypt3DES:使用3DES解密算法对数据进行解密。包括创建3DES密码块,设置CBC模式解密器,并进行解密,然后去除PKCS5填充。

主函数:

main函数定义了密钥和初始向量(IV),以及要加密的明文。然后调用加密函数和解密函数,并打印结果。

如何运行

将上述代码保存为一个文件,例如main.go。

在终端中运行以下命令:

sh 复制代码
go run main.go

结论

本文介绍了如何使用Go语言实现TripleDES加密和解密。我们讨论了TripleDES的基本概念,并提供了完整的代码示例。

相关推荐
一只爱打拳的程序猿7 分钟前
【Spring】更加简单的将对象存入Spring中并使用
java·后端·spring
杨荧9 分钟前
【JAVA毕业设计】基于Vue和SpringBoot的服装商城系统学科竞赛管理系统
java·开发语言·vue.js·spring boot·spring cloud·java-ee·kafka
白子寰15 分钟前
【C++打怪之路Lv14】- “多态“篇
开发语言·c++
王俊山IT27 分钟前
C++学习笔记----10、模块、头文件及各种主题(一)---- 模块(5)
开发语言·c++·笔记·学习
为将者,自当识天晓地。29 分钟前
c++多线程
java·开发语言
小政爱学习!31 分钟前
封装axios、环境变量、api解耦、解决跨域、全局组件注入
开发语言·前端·javascript
k09331 小时前
sourceTree回滚版本到某次提交
开发语言·前端·javascript
神奇夜光杯1 小时前
Python酷库之旅-第三方库Pandas(202)
开发语言·人工智能·python·excel·pandas·标准库及第三方库·学习与成长
Themberfue1 小时前
Java多线程详解⑤(全程干货!!!)线程安全问题 || 锁 || synchronized
java·开发语言·线程·多线程·synchronized·
plmm烟酒僧1 小时前
Windows下QT调用MinGW编译的OpenCV
开发语言·windows·qt·opencv