各种加密算法在Go语言中的使用
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了各种加密算法在Go语言中的使用相关的知识,希望对你有一定的参考价值。
使用SHA256、MD5、RIPEMD160import (
"fmt"
"crypto/sha256"
"os"
"io"
"crypto/md5"
"golang.org/x/crypto/ripemd160"
)
func main() {
str := "hello world"
sum := sha256.Sum256([]byte(str))
fmt.Printf("SHA256:%x\n", sum)
fileSha156()
result := md5.Sum([]byte(str))
fmt.Printf("MD5:%x\n", result)
hasher := ripemd160.New()
// 将加密内容的字节数组拷贝到ripemd160
hasher.Write([]byte(str))
fmt.Printf("RIPEMD160:%x", hasher.Sum(nil))
}
/**
* 使用SHA256加密文件内容
*/
func fileSha156() {
file, err := os.OpenFile("e:/test.txt", os.O_RDONLY, 0777)
if err != nil {
panic(err)
}
defer file.Close()
h := sha256.New()
// 将文件内容拷贝到sha256中
io.Copy(h, file)
fmt.Printf("%x\n", h.Sum(nil))
}
使用DES
import (
"bytes"
"crypto/cipher" //cipher密码
"crypto/des"
"encoding/base64" //将对象转换成字符串
"fmt"
)
/**
* DES加密方法
*/
func MyDesEncrypt(orig, key string) string{
// 将加密内容和秘钥转成字节数组
origData := []byte(orig)
k := []byte(key)
// 秘钥分组
block, _ := des.NewCipher(k)
//将明文按秘钥的长度做补全操作
origData = PKCS5Padding(origData, block.BlockSize())
//设置加密方式-CBC
blockMode := cipher.NewCBCDecrypter(block, k)
//创建明文长度的字节数组
crypted := make([]byte, len(origData))
//加密明文
blockMode.CryptBlocks(crypted, origData)
//将字节数组转换成字符串,base64编码
return base64.StdEncoding.EncodeToString(crypted)
}
/**
* DES解密方法
*/
func MyDESDecrypt(data string, key string) string {
k := []byte(key)
//将加密字符串用base64转换成字节数组
crypted, _ := base64.StdEncoding.DecodeString(data)
//将字节秘钥转换成block快
block, _ := des.NewCipher(k)
//设置解密方式-CBC
blockMode := cipher.NewCBCEncrypter(block, k)
//创建密文大小的数组变量
origData := make([]byte, len(crypted))
//解密密文到数组origData中
blockMode.CryptBlocks(origData, crypted)
//去掉加密时补全的部分
origData = PKCS5UnPadding(origData)
return string(origData)
}
/**
* 实现明文的补全
* 如果ciphertext的长度为blockSize的整数倍,则不需要补全
* 否则差几个则被几个,例:差5个则补5个5
*/
func PKCS5Padding(ciphertext []byte, blockSize int) []byte {
padding := blockSize - len(ciphertext)%blockSize
padtext := bytes.Repeat([]byte{byte(padding)}, padding)
return append(ciphertext, padtext...)
}
/**
* 实现去补码,PKCS5Padding的反函数
*/
func PKCS5UnPadding(origData []byte) []byte {
length := len(origData)
// 去掉最后一个字节 unpadding 次
unpadding := int(origData[length-1])
return origData[:(length - unpadding)]
}
func main() {
orig := "Hello World!"
fmt.Println("原文:", orig)
//声明秘钥,利用此秘钥实现明文的加密和密文的解密,长度必须为8
key := "12345678"
//加密
encyptCode := MyDesEncrypt(orig, key)
fmt.Println("密文:", encyptCode)
//解密
decyptCode := MyDESDecrypt(encyptCode, key)
fmt.Println("解密结果:", decyptCode)
}
使用3DES
import (
"bytes"
"crypto/cipher"
"crypto/des"
"encoding/base64"
"fmt"
)
func main() {
orig := "hello world"
// 3DES的秘钥长度必须为24位
key := "123456781234567812345678"
fmt.Println("原文:", orig)
encryptCode := TripleDesEncrypt(orig, key)
fmt.Println("密文:", encryptCode)
decryptCode := TipleDesDecrypt(encryptCode, key)
fmt.Println("解密结果:", decryptCode)
}
/**
* 加密
*/
func TripleDesEncrypt(orig, key string) string {
// 转成字节数组
origData := []byte(orig)
k := []byte(key)
// 3DES的秘钥长度必须为24位
block, _ := des.NewTripleDESCipher(k)
// 补全码
origData = PKCS5Padding(origData, block.BlockSize())
// 设置加密方式
blockMode := cipher.NewCBCEncrypter(block, k[:8])
// 创建密文数组
crypted := make([]byte, len(origData))
// 加密
blockMode.CryptBlocks(crypted, origData)
return base64.StdEncoding.EncodeToString(crypted)
}
/**
* 解密
*/
func TipleDesDecrypt(crypted string, key string) string {
// 用base64转成字节数组
cryptedByte, _ := base64.StdEncoding.DecodeString(crypted)
// key转成字节数组
k := []byte(key)
block, _ := des.NewTripleDESCipher(k)
blockMode := cipher.NewCBCDecrypter(block, k[:8])
origData := make([]byte, len(cryptedByte))
blockMode.CryptBlocks(origData, cryptedByte)
origData = PKCS5UnPadding(origData)
return string(origData)
}
func PKCS5Padding(orig []byte, size int) []byte {
length := len(orig)
padding := size - length%size
paddintText := bytes.Repeat([]byte{byte(padding)}, padding)
return append(orig, paddintText...)
}
func PKCS5UnPadding(origData []byte) []byte {
length := len(origData)
// 去掉最后一个字节 unpadding 次
unpadding := int(origData[length-1])
return origData[:(length - unpadding)]
}
使用AES
import (
"bytes"
"crypto/aes"
"fmt"
"crypto/cipher"
"encoding/base64"
)
func main() {
orig := "hello world"
key := "123456781234567812345678"
fmt.Println("原文:", orig)
encryptCode := AesEncrypt(orig, key)
fmt.Println("密文:" , encryptCode)
decryptCode := AesDecrypt(encryptCode, key)
fmt.Println("解密结果:", decryptCode)
}
func AesEncrypt(orig string, key string) string {
// 转成字节数组
origData := []byte(orig)
k := []byte(key)
// 分组秘钥
block, _ := aes.NewCipher(k)
// 获取秘钥块的长度
blockSize := block.BlockSize()
// 补全码
origData = PKCS7Padding(origData, blockSize)
// 加密模式
blockMode := cipher.NewCBCEncrypter(block, k[:blockSize])
// 创建数组
cryted := make([]byte, len(origData))
// 加密
blockMode.CryptBlocks(cryted, origData)
return base64.StdEncoding.EncodeToString(cryted)
}
func AesDecrypt(cryted string, key string) string {
// 转成字节数组
crytedByte, _ := base64.StdEncoding.DecodeString(cryted)
k := []byte(key)
// 分组秘钥
block, _ := aes.NewCipher(k)
// 获取秘钥块的长度
blockSize := block.BlockSize()
// 加密模式
blockMode := cipher.NewCBCDecrypter(block, k[:blockSize])
// 创建数组
orig := make([]byte, len(crytedByte))
// 解密
blockMode.CryptBlocks(orig, crytedByte)
// 去补全码
orig = PKCS7UnPadding(orig)
return string(orig)
}
//补码
func PKCS7Padding(ciphertext []byte, blocksize int) []byte {
padding := blocksize - len(ciphertext)%blocksize
padtext := bytes.Repeat([]byte{byte(padding)}, padding)
return append(ciphertext, padtext...)
}
//去码
func PKCS7UnPadding(origData []byte) []byte {
length := len(origData)
unpadding := int(origData[length-1])
return origData[:(length - unpadding)]
}
以上是关于各种加密算法在Go语言中的使用的主要内容,如果未能解决你的问题,请参考以下文章
go语言教程哪里有?Go从入门到精通系列视频3.1 对称加密算法